@dollhousemcp/mcp-server 2.0.8 → 2.0.10

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 (37) hide show
  1. package/dist/elements/ensembles/Ensemble.d.ts +9 -0
  2. package/dist/elements/ensembles/Ensemble.d.ts.map +1 -1
  3. package/dist/elements/ensembles/Ensemble.js +71 -4
  4. package/dist/generated/version.d.ts +2 -2
  5. package/dist/generated/version.d.ts.map +1 -1
  6. package/dist/generated/version.js +3 -3
  7. package/dist/handlers/mcp-aql/IntrospectionResolver.d.ts +57 -0
  8. package/dist/handlers/mcp-aql/IntrospectionResolver.d.ts.map +1 -1
  9. package/dist/handlers/mcp-aql/IntrospectionResolver.js +181 -2
  10. package/dist/handlers/mcp-aql/MCPAQLHandler.d.ts +8 -0
  11. package/dist/handlers/mcp-aql/MCPAQLHandler.d.ts.map +1 -1
  12. package/dist/handlers/mcp-aql/MCPAQLHandler.js +32 -6
  13. package/dist/handlers/mcp-aql/OperationRouter.d.ts.map +1 -1
  14. package/dist/handlers/mcp-aql/OperationRouter.js +6 -1
  15. package/dist/handlers/mcp-aql/OperationSchema.d.ts +7 -0
  16. package/dist/handlers/mcp-aql/OperationSchema.d.ts.map +1 -1
  17. package/dist/handlers/mcp-aql/OperationSchema.js +120 -8
  18. package/dist/handlers/mcp-aql/SchemaDispatcher.d.ts.map +1 -1
  19. package/dist/handlers/mcp-aql/SchemaDispatcher.js +11 -1
  20. package/dist/handlers/mcp-aql/types.d.ts.map +1 -1
  21. package/dist/handlers/mcp-aql/types.js +11 -1
  22. package/dist/index.js +19 -1
  23. package/dist/server/tools/MCPAQLTools.d.ts.map +1 -1
  24. package/dist/server/tools/MCPAQLTools.js +7 -1
  25. package/dist/web/public/app.js +118 -7
  26. package/dist/web/public/dollhouse-logo.png +0 -0
  27. package/dist/web/public/index.html +5 -2
  28. package/dist/web/public/logs.js +56 -1
  29. package/dist/web/public/metrics.js +32 -1
  30. package/dist/web/public/setup.css +79 -0
  31. package/dist/web/public/setup.js +90 -0
  32. package/dist/web/public/styles.css +3 -1
  33. package/dist/web/server.d.ts +1 -1
  34. package/dist/web/server.d.ts.map +1 -1
  35. package/dist/web/server.js +19 -9
  36. package/package.json +3 -3
  37. package/server.json +2 -2
@@ -26,7 +26,7 @@ import { PermissionGuard } from './PermissionGuard.js';
26
26
  import { ElementType } from './types.js';
27
27
  import { getAllowedGroupByFields } from '../../services/query/AggregationService.js';
28
28
  import { VALIDATION_PATTERNS } from '../../security/constants.js';
29
- import { getOperationSchema, getAnyOperationSchema, schemaToParameterInfo, } from './OperationSchema.js';
29
+ import { getOperationSchema, getAnyOperationSchema, schemaToParameterInfo, ALL_OPERATION_SCHEMAS, } from './OperationSchema.js';
30
30
  // ============================================================================
31
31
  // Type Definitions Registry
32
32
  // ============================================================================
@@ -926,5 +926,184 @@ export class IntrospectionResolver {
926
926
  lines.push('\nUse introspect with name parameter for details.');
927
927
  return lines.join('\n');
928
928
  }
929
+ // ==========================================================================
930
+ // Capabilities (Issue #1760)
931
+ // ==========================================================================
932
+ /**
933
+ * Get server capabilities grouped by user-intent category.
934
+ * Reads category from each operation's schema definition at runtime.
935
+ * Designed for extensibility — additional CapabilitySources (e.g. portfolio
936
+ * elements from the capability index) can be registered via registerSource().
937
+ *
938
+ * @param params - Optional parameters
939
+ * @param params.category - Filter to a specific category
940
+ * @returns CapabilitiesResult with categorized operations
941
+ * @see Issue #1760 - get_capabilities operation
942
+ */
943
+ static getCapabilities(params) {
944
+ const filterCategory = params.category;
945
+ const { categories, sortedCategories, sourceTypes } = this.buildCategoryMap();
946
+ // Apply category filter if requested
947
+ if (filterCategory) {
948
+ return this.filterByCategory(filterCategory, categories, sortedCategories, sourceTypes);
949
+ }
950
+ const totalCapabilities = Object.values(categories).reduce((sum, cat) => sum + cat.capabilities.length, 0);
951
+ return {
952
+ categories,
953
+ totalCapabilities,
954
+ sources: sourceTypes,
955
+ hint: 'Use introspect with { query: "operations", name: "<operation>" } for full parameter details, examples, and permissions.',
956
+ };
957
+ }
958
+ /**
959
+ * Build the full category map from all registered capability sources.
960
+ * Returns sorted categories with descriptions and merged entries.
961
+ */
962
+ static buildCategoryMap() {
963
+ const mergedMap = {};
964
+ const sourceTypes = [];
965
+ for (const source of capabilitySources) {
966
+ sourceTypes.push(source.sourceType);
967
+ const caps = source.getCapabilities();
968
+ for (const [cat, entries] of Object.entries(caps)) {
969
+ if (!mergedMap[cat])
970
+ mergedMap[cat] = [];
971
+ mergedMap[cat].push(...entries);
972
+ }
973
+ }
974
+ // Sort entries within each category alphabetically
975
+ for (const entries of Object.values(mergedMap)) {
976
+ entries.sort((a, b) => a.name.localeCompare(b.name));
977
+ }
978
+ // Sort categories alphabetically ("Other" last)
979
+ const sortedCategories = Object.keys(mergedMap).sort((a, b) => {
980
+ if (a === 'Other')
981
+ return 1;
982
+ if (b === 'Other')
983
+ return -1;
984
+ return a.localeCompare(b);
985
+ });
986
+ const categories = {};
987
+ for (const cat of sortedCategories) {
988
+ categories[cat] = {
989
+ description: CATEGORY_DESCRIPTIONS[cat] || `${cat} operations`,
990
+ capabilities: mergedMap[cat],
991
+ };
992
+ }
993
+ return { categories, sortedCategories, sourceTypes };
994
+ }
995
+ /**
996
+ * Filter the category map to a single matching category (case-insensitive).
997
+ */
998
+ static filterByCategory(filterCategory, categories, sortedCategories, sourceTypes) {
999
+ const lowerFilter = filterCategory.toLowerCase();
1000
+ const filtered = {};
1001
+ for (const [catName, catData] of Object.entries(categories)) {
1002
+ if (catName.toLowerCase() === lowerFilter) {
1003
+ filtered[catName] = catData;
1004
+ }
1005
+ }
1006
+ if (Object.keys(filtered).length === 0) {
1007
+ return {
1008
+ categories: {},
1009
+ availableCategories: sortedCategories,
1010
+ hint: `No category matching "${filterCategory}". Use get_capabilities without a filter to see all categories.`,
1011
+ };
1012
+ }
1013
+ return {
1014
+ categories: filtered,
1015
+ sources: sourceTypes,
1016
+ hint: 'Use introspect with { query: "operations", name: "<operation>" } for full details on any operation.',
1017
+ };
1018
+ }
1019
+ /**
1020
+ * Register an additional capability source.
1021
+ * Future element sources (reading from the capability index) can be
1022
+ * plugged in here without modifying the get_capabilities handler.
1023
+ * @see Issue #1760 - extensibility for portfolio element capabilities
1024
+ */
1025
+ static registerSource(source) {
1026
+ capabilitySources.push(source);
1027
+ }
1028
+ /**
1029
+ * Truncate a description to a brief one-liner.
1030
+ * Takes the first sentence (up to first period followed by space or end).
1031
+ */
1032
+ static toBrief(description) {
1033
+ if (!description || typeof description !== 'string') {
1034
+ return 'No description available';
1035
+ }
1036
+ const match = /^[^.]*\./.exec(description);
1037
+ if (match && match[0].length <= 120) {
1038
+ return match[0];
1039
+ }
1040
+ if (description.length <= 120)
1041
+ return description;
1042
+ return description.slice(0, 117) + '...';
1043
+ }
929
1044
  }
930
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IntrospectionResolver.js","sourceRoot":"","sources":["../../../src/handlers/mcp-aql/IntrospectionResolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * IntrospectionResolver - GraphQL-style introspection for MCP-AQL\n *\n * Provides discovery capabilities for LLMs to understand available operations,\n * their parameters, return types, and examples.\n *\n * INTROSPECTION QUERIES:\n * - operations: List all available operations\n * - operation(name): Get details for a specific operation\n * - types: List available types (ElementType, etc.)\n * - type(name): Get details for a specific type\n * - categories: Category format rules + discovery guidance (Issue #631)\n *\n * DESIGN RATIONALE:\n * - Token-efficient: Returns minimal but useful information\n * - Self-documenting: Operations describe themselves\n * - Read-only: Safe to call at any time (no side effects)\n *\n * SCHEMA INTEGRATION (Issue #254):\n * - Schema-driven operations get their metadata from OperationSchema\n * - Legacy operations use the fallback OPERATION_PARAMETERS/OPERATION_EXAMPLES\n * - This ensures single source of truth for schema-driven operations\n */\n\nimport { OPERATION_ROUTES, type CRUDEndpoint } from './OperationRouter.js';\nimport { PermissionGuard, type EndpointPermissions } from './PermissionGuard.js';\nimport { ElementType } from './types.js';\nimport { getAllowedGroupByFields } from '../../services/query/AggregationService.js';\nimport { VALIDATION_PATTERNS } from '../../security/constants.js';\nimport {\n  getOperationSchema,\n  getAnyOperationSchema,\n  schemaToParameterInfo,\n  type OperationDef,\n} from './OperationSchema.js';\n\n// ============================================================================\n// Response Types\n// ============================================================================\n\n/**\n * Basic information about an operation (used in list responses)\n */\nexport interface OperationInfo {\n  /** Operation name (e.g., 'create_element') */\n  name: string;\n  /** CRUD endpoint this operation belongs to */\n  endpoint: string;\n  /** Brief description of what the operation does */\n  description: string;\n}\n\n/**\n * Parameter information for operation details\n */\nexport interface ParameterInfo {\n  /** Parameter name */\n  name: string;\n  /** Parameter type (e.g., 'string', 'ElementType', 'object') */\n  type: string;\n  /** Whether the parameter is required */\n  required: boolean;\n  /** Brief description of the parameter */\n  description: string;\n  /** Default value if any */\n  default?: unknown;\n}\n\n/**\n * Return type information\n */\nexport interface TypeInfo {\n  /** Type name */\n  name: string;\n  /** Type kind (enum, object, scalar, union) */\n  kind: 'enum' | 'object' | 'scalar' | 'union';\n  /** Brief description */\n  description?: string;\n}\n\n/**\n * Detailed information about a specific operation\n */\nexport interface OperationDetails {\n  /** Operation name */\n  name: string;\n  /** CRUD endpoint */\n  endpoint: string;\n  /** MCP tool name (e.g., 'mcp_aql_read') */\n  mcpTool: string;\n  /** Full description */\n  description: string;\n  /** Permission flags */\n  permissions: EndpointPermissions;\n  /** Parameter definitions */\n  parameters: ParameterInfo[];\n  /** Return type information */\n  returns: TypeInfo;\n  /** Usage examples */\n  examples: string[];\n  /** Alternative operation names that resolve to this operation */\n  aliases?: string[];\n}\n\n/**\n * Detailed type information with enum values or object fields\n */\nexport interface TypeDetails {\n  /** Type name */\n  name: string;\n  /** Type kind */\n  kind: 'enum' | 'object' | 'scalar' | 'union';\n  /** Full description */\n  description: string;\n  /** Enum values (for enum types) */\n  values?: string[];\n  /** Object fields (for object types) */\n  fields?: ParameterInfo[];\n  /** Union member types (for union types) */\n  members?: string[];\n}\n\n/**\n * Format specification for an element type (Issue #715)\n */\nexport interface FormatSpec {\n  /** Element type this spec describes */\n  elementType: string;\n  /** File format used for storage */\n  fileFormat: string;\n  /** Required fields in frontmatter */\n  requiredFields: string[];\n  /** Optional fields in frontmatter */\n  optionalFields: string[];\n  /** Guidance on using instructions vs content fields */\n  dualFieldGuidance: string;\n  /** Syntax notes specific to this element type */\n  syntaxNotes: string[];\n  /** Minimal working example */\n  minimalExample: string;\n  /** Full-featured example */\n  fullExample: string;\n  /** Naming conventions for this element type */\n  namingConventions: string[];\n}\n\n/**\n * Result of an introspection query\n */\nexport interface IntrospectionResult {\n  /** List of operations (for 'operations' query) */\n  operations?: OperationInfo[];\n  /** Single operation details (for 'operation(name)' query) */\n  operation?: OperationDetails | null;\n  /** List of types (for 'types' query) */\n  types?: TypeInfo[];\n  /** Single type details (for 'type(name)' query) */\n  type?: TypeDetails | null;\n  /** Format specification (for 'format' query) */\n  formatSpec?: FormatSpec | FormatSpec[] | null;\n  /** Category discovery info (for 'categories' query, Issue #631) */\n  categories?: Record<string, unknown>;\n}\n\n// ============================================================================\n// Type Definitions Registry\n// ============================================================================\n\n/**\n * Registry of all types available in MCP-AQL\n * This is the source of truth for type introspection\n */\nconst TYPE_DEFINITIONS: Record<string, TypeDetails> = {\n  ElementType: {\n    name: 'ElementType',\n    kind: 'enum',\n    description: 'The 6 core element types supported by DollhouseMCP',\n    values: Object.values(ElementType),\n  },\n  CRUDEndpoint: {\n    name: 'CRUDEndpoint',\n    kind: 'enum',\n    description: 'CRUDE endpoint categories for operation classification (CRUD + Execute)',\n    values: ['CREATE', 'READ', 'UPDATE', 'DELETE', 'EXECUTE'],\n  },\n  OperationInput: {\n    name: 'OperationInput',\n    kind: 'object',\n    description: 'Standard input structure for all MCP-AQL operations',\n    fields: [\n      {\n        name: 'operation',\n        type: 'string',\n        required: true,\n        description: 'The operation to perform',\n      },\n      {\n        name: 'elementType',\n        type: 'ElementType',\n        required: false,\n        description: 'Element type for element operations',\n      },\n      {\n        name: 'params',\n        type: 'object',\n        required: false,\n        description: 'Operation-specific parameters',\n      },\n    ],\n  },\n  OperationResult: {\n    name: 'OperationResult',\n    kind: 'union',\n    description: 'Standard result type for all operations (success or failure)',\n    members: ['OperationSuccess', 'OperationFailure'],\n  },\n  OperationSuccess: {\n    name: 'OperationSuccess',\n    kind: 'object',\n    description: 'Successful operation result',\n    fields: [\n      {\n        name: 'success',\n        type: 'boolean',\n        required: true,\n        description: 'Always true for success',\n        default: true,\n      },\n      {\n        name: 'data',\n        type: 'unknown',\n        required: true,\n        description: 'Operation-specific result payload',\n      },\n    ],\n  },\n  OperationFailure: {\n    name: 'OperationFailure',\n    kind: 'object',\n    description: 'Failed operation result',\n    fields: [\n      {\n        name: 'success',\n        type: 'boolean',\n        required: true,\n        description: 'Always false for failure',\n        default: false,\n      },\n      {\n        name: 'error',\n        type: 'string',\n        required: true,\n        description: 'Human-readable error message',\n      },\n    ],\n  },\n  EndpointPermissions: {\n    name: 'EndpointPermissions',\n    kind: 'object',\n    description: 'Permission flags for CRUD endpoints',\n    fields: [\n      {\n        name: 'readOnly',\n        type: 'boolean',\n        required: true,\n        description: 'Whether the operation only reads data',\n      },\n      {\n        name: 'destructive',\n        type: 'boolean',\n        required: true,\n        description: 'Whether the operation can delete or modify data',\n      },\n    ],\n  },\n};\n\n// ============================================================================\n// Element Format Specifications (Issue #715)\n// ============================================================================\n\n/**\n * Map from ElementType value to plural form for normalization.\n * \"memories\" -> \"memory\", \"personas\" -> \"persona\", etc.\n */\nconst PLURAL_TO_TYPE: Record<string, string> = {\n  personas: 'persona',\n  skills: 'skill',\n  templates: 'template',\n  agents: 'agent',\n  memories: 'memory',\n  ensembles: 'ensemble',\n};\n\n/**\n * Normalize a user-provided type name to an ElementType value.\n * Handles: lowercase, plural forms, leading/trailing whitespace, non-string input.\n */\nfunction normalizeTypeName(name: unknown): string | undefined {\n  if (!name || typeof name !== 'string') return undefined;\n  const lower = name.trim().toLowerCase();\n  if (Object.values(ElementType).includes(lower as ElementType)) {\n    return lower;\n  }\n  return PLURAL_TO_TYPE[lower];\n}\n\nconst SHARED_NAMING = [\n  'Use lowercase kebab-case: my-element-name',\n  'Max 100 characters, must start with a letter',\n  'Allowed: letters, digits, hyphens, underscores',\n];\n\n/**\n * Format specifications for each element type.\n * Returned by introspect query: \"format\".\n *\n * @see Issue #715 - Proactive LLM guidance for element creation\n */\nconst FORMAT_SPECS: Record<string, FormatSpec> = {\n  persona: {\n    elementType: 'persona',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'instructions', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Behavioral directives in command voice (\"You ARE...\", \"ALWAYS...\", \"NEVER...\"). content: Optional background lore, context, or reference material. For personas, instructions is the primary field.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Frontmatter delimited by --- on its own line',\n      'Body text after frontmatter becomes the instructions field',\n      'No template variable substitution in personas',\n      'gatekeeper: Dynamic security policy — takes effect when this persona is activated, reverts when deactivated. Example: a \"focused-work\" persona that denies web browsing tools while active, or an \"open-research\" persona that allows broad access. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }. Priority: deny > confirm > allow > route default.',\n    ],\n    minimalExample: `---\nname: my-persona\ndescription: A helpful assistant\n---\nYou ARE a helpful assistant. ALWAYS be concise and accurate.`,\n    fullExample: `---\nname: security-analyst\ndescription: Cybersecurity specialist focused on threat modeling\nversion: 1\ntags: [security, analysis]\nauthor: team-lead\n---\nYou ARE a cybersecurity expert with 15 years of experience.\nALWAYS consider threat models before suggesting solutions.\nNEVER recommend security through obscurity.\nPRIORITIZE defense-in-depth strategies.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the role: security-analyst, code-reviewer, technical-writer',\n    ],\n  },\n\n  skill: {\n    elementType: 'skill',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'instructions', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Behavioral directives for when the skill is active (\"When triggered, ANALYZE...\", \"ALWAYS check...\"). content: Domain knowledge, reference material, checklists, examples. Best practice: use BOTH for rich skills.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Frontmatter delimited by --- on its own line',\n      'Body text after frontmatter becomes the content field',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'gatekeeper: Dynamic security policy — takes effect when this skill is activated, reverts when deactivated. Example: a \"code-review\" skill that auto-approves read operations but confirms edits, or a \"read-only\" skill that denies all write operations. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: code-review\ndescription: Reviews code for quality issues\n---\nWhen reviewing code: ALWAYS check for security vulnerabilities first.`,\n    fullExample: `---\nname: code-review\ndescription: Reviews code for quality and security\nversion: 1\ntags: [development, quality]\nauthor: dev-team\ncategory: development\n---\nWhen reviewing code: ALWAYS check for security vulnerabilities first.\nANALYZE complexity and suggest simplifications.\nFORMAT feedback as actionable bullet points.\n\n# Reference Material\n\n## Security Checklist\n- SQL injection\n- XSS vulnerabilities\n- Unvalidated input\n\n## Quality Metrics\n- Cyclomatic complexity < 10\n- Test coverage > 80%`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the capability: code-review, threat-modeling, data-analysis',\n    ],\n  },\n\n  template: {\n    elementType: 'template',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'variables', 'gatekeeper'],\n    dualFieldGuidance: 'content (REQUIRED): The template body. Use {{variable_name}} for substitution. instructions: Not typically used for templates. For page-level templates with CSS/JS, use section format instead of plain content.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Variable syntax: {{variable_name}} — simple substitution only',\n      'NO Handlebars: {{#if}}, {{#each}}, {{> partial}} are NOT supported',\n      'Section format for page templates: <template>HTML with {{vars}}</template> <style>CSS</style> <script>JS</script>',\n      'In section format: only <template> is variable-processed; <style> and <script> are raw passthrough (}} is safe there)',\n      'Declare variables in frontmatter: variables: [{ name, type, required, description }]',\n      'For lists, tables, or conditional content: pass pre-formatted markdown strings as variables',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'gatekeeper: Dynamic security policy — takes effect when this template is activated, reverts when deactivated. Example: a sensitive report template that denies deletion while active, protecting it from accidental removal during use. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: bug-report\ndescription: Bug report template\nvariables:\n  - { name: summary, type: string, required: true }\n  - { name: steps, type: string, required: true }\n---\n## Bug Report\n\n**Summary:** {{summary}}\n**Steps to Reproduce:** {{steps}}`,\n    fullExample: `---\nname: dashboard-page\ndescription: Full-page dashboard with styles and scripts\nvariables:\n  - { name: title, type: string, required: true }\n  - { name: body, type: string, required: false }\n---\n<template>\n<!DOCTYPE html>\n<html>\n<head><title>{{title}}</title></head>\n<body>{{body}}</body>\n</html>\n</template>\n\n<style>\nbody { font-family: sans-serif; }\n.card { border: 1px solid #ccc; } /* }} safe here */\n</style>\n\n<script>\nvar state = { status: \"all\" };\nfunction update() { return { bar: baz }; } // }} safe here\n</script>`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the output: bug-report, meeting-notes, dashboard-page',\n    ],\n  },\n\n  agent: {\n    elementType: 'agent',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'instructions', 'content', 'goal', 'activates', 'tools', 'systemPrompt', 'autonomy', 'resilience', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Semantic behavioral profile — personality and approach (distinct from systemPrompt). content: Reference material the agent can consult during execution. goal (RECOMMENDED): Structured goal with template, parameters, and successCriteria. systemPrompt: LLM system prompt for execution context.',\n    syntaxNotes: [\n      'File extension: .md',\n      'goal.template uses {param} placeholders (single braces, NOT {{}})',\n      'goal.parameters: array of { name, type, required, description, default? }',\n      'goal.successCriteria: string array of completion conditions',\n      'activates: { personas?: string[], skills?: string[], memories?: string[], templates?: string[], ensembles?: string[] }',\n      'tools: { allowed: string[], denied?: string[] }',\n      'autonomy: { maxAutonomousSteps, allowedActions, requireConfirmation } (defaults apply if omitted)',\n      'resilience: Governs automatic recovery during execute_agent. { onStepLimitReached?: \"pause\"|\"continue\"|\"restart\", onExecutionFailure?: \"pause\"|\"retry\"|\"restart-fresh\", maxRetries?: number (default 3), maxContinuations?: number (default 10), retryBackoff?: \"linear\"|\"exponential\", preserveState?: boolean }. Without resilience, execution pauses at limits and failures (safe default).',\n      'activates lifecycle: Elements in activates are automatically activated when execute_agent starts — their gatekeeper policies, instructions, and capabilities become active for the execution duration.',\n      'gatekeeper: Dynamic security policy — takes effect when this agent is activated, reverts when deactivated. Gives users composable security control: activate a locked-down agent and writes are blocked; deactivate it and full access returns. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?: string[], blockedTypes?: string[] } }. allow/confirm/deny are operation name patterns (e.g. \"read_*\", \"execute_agent\", \"delete_element\"). scopeRestrictions limits which element types the policy governs. Priority: deny > confirm > allow > route default. If omitted, inherits system defaults (which already require confirmation for sensitive operations).',\n    ],\n    minimalExample: `---\nname: code-reviewer\ndescription: Reviews code for quality issues\n---\nYou are a thorough code reviewer.`,\n    fullExample: `---\nname: code-reviewer\ndescription: Reviews code for quality and security issues\nversion: 1\ntags: [development, security]\nauthor: dev-team\ngoal:\n  template: \"Review the code at {path} for {focus_area}\"\n  parameters:\n    - { name: path, type: string, required: true, description: \"File or directory\" }\n    - { name: focus_area, type: string, required: false, description: \"security | quality | performance\", default: quality }\n  successCriteria:\n    - All issues documented\n    - Severity ratings assigned\n    - Fixes suggested\nactivates:\n  skills: [code-review]\n  personas: [security-analyst]\ntools:\n  allowed: [read_file, list_directory]\nsystemPrompt: Be specific about line numbers and provide concrete fix suggestions.\nautonomy:\n  maxAutonomousSteps: 10\nresilience:\n  onStepLimitReached: continue\n  onExecutionFailure: retry\n  maxRetries: 3\n  maxContinuations: 5\n  retryBackoff: exponential\ngatekeeper:\n  allow: [read_element, search_elements, query_elements, list_elements]\n  confirm: [execute_agent, edit_element]\n  deny: [delete_element]\n---\nYou are a thorough code reviewer who prioritizes security.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the agent role: code-reviewer, data-pipeline, report-generator',\n    ],\n  },\n\n  memory: {\n    elementType: 'memory',\n    fileFormat: 'YAML',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'retentionDays', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'content: Initial entry content added at creation time. instructions: Not typically used for memories. Use addEntry operation to append structured entries after creation.',\n    syntaxNotes: [\n      'File extension: .yml',\n      'Entries are structured YAML objects with timestamp, content, tags, metadata',\n      'Use addEntry operation to add entries (not edit_element)',\n      'retentionDays controls automatic expiry of entries',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'Naming convention for agent-linked memories: agent-{agent-name}-context',\n      'Naming convention for persona-linked memories: persona-{persona-name}-preferences',\n      'gatekeeper: Dynamic security policy — takes effect when this memory is activated, reverts when deactivated. Example: a confidential project memory that blocks deletion and confirms edits while active. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `# Created via create_element:\n{ operation: \"create_element\", elementType: \"memory\", params: {\n  element_name: \"project-context\",\n  description: \"Architecture decisions\"\n} }`,\n    fullExample: `# Created via create_element:\n{ operation: \"create_element\", elementType: \"memory\", params: {\n  element_name: \"project-context\",\n  description: \"Architecture decisions and project context\",\n  content: \"Using PostgreSQL for ACID compliance.\",\n  metadata: { tags: [\"architecture\", \"database\"], retentionDays: 365 }\n} }\n\n# Add entries via addEntry:\n{ operation: \"addEntry\", params: {\n  element_name: \"project-context\",\n  content: \"Switched to Redis for caching layer.\",\n  tags: [\"architecture\", \"cache\"]\n} }`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Agent-linked: agent-{agent-name}-context',\n      'Persona-linked: persona-{persona-name}-preferences',\n      'Session-scoped: session-context',\n      'Domain-specific: project-context, team-decisions',\n    ],\n  },\n\n  ensemble: {\n    elementType: 'ensemble',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description', 'metadata.elements'],\n    optionalFields: ['version', 'tags', 'author', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'content: Optional description of how the ensemble coordinates its elements. instructions: Not used for ensembles. The elements array in metadata is the core configuration.',\n    syntaxNotes: [\n      'File extension: .md',\n      'metadata.elements is REQUIRED: array of { name, type, role }',\n      'role values: \"primary\", \"support\", \"override\", \"monitor\", \"core\"',\n      'type must be a valid ElementType: persona, skill, template, agent, memory',\n      'Referenced elements must exist in the portfolio',\n      'At least one element required; elements validated at creation time',\n      'gatekeeper: Dynamic security policy — takes effect when this ensemble is activated, reverts when deactivated. Ensembles can define broad security postures: activate a \"production-safe\" ensemble and destructive operations are blocked across all its member elements. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: security-team\ndescription: Security analysis ensemble\nmetadata:\n  elements:\n    - { name: security-analyst, type: persona, role: primary }\n    - { name: threat-modeling, type: skill, role: support }\n---`,\n    fullExample: `---\nname: security-team\ndescription: Security analysis ensemble combining analyst persona with threat modeling\nversion: 1\ntags: [security, analysis]\nauthor: team-lead\nmetadata:\n  elements:\n    - { name: security-analyst, type: persona, role: primary }\n    - { name: threat-modeling, type: skill, role: support }\n    - { name: penetration-testing, type: skill, role: support }\n---\nCoordinates security analysis across multiple domains.\nThe security-analyst persona provides the behavioral foundation,\nwhile skills supply domain-specific capabilities.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the team or combination: security-team, content-pipeline, full-stack-review',\n    ],\n  },\n};\n\n// ============================================================================\n// Operation Parameter Definitions\n// ============================================================================\n\n/**\n * Parameter definitions for each operation\n * These are used to generate operation details\n */\nconst OPERATION_PARAMETERS: Record<string, ParameterInfo[]> = {\n  // CREATE operations\n  create_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'description', type: 'string', required: true, description: 'Element description' },\n    // Issue #602 resolved: Both 'instructions' and 'content' are first-class fields with distinct semantic roles.\n    { name: 'instructions', type: 'string', required: false, description: 'Behavioral INSTRUCTIONS — written in active/command voice as directives the AI must follow. For personas: \"You ARE a security expert. ALWAYS check for vulnerabilities.\" For skills: \"When triggered, ANALYZE code systematically.\" For agents: semantic behavioral profile (distinct from systemPrompt). Optional for memories/ensembles.' },\n    { name: 'content', type: 'string', required: false, description: 'Reference material, knowledge, and context. ELEMENT-SPECIFIC USAGE: Templates (REQUIRED): the template body — use {{variable_name}} for substitution. For page templates with CSS/JS use section format: <template>HTML with {{vars}}</template><style>/* }} safe here */</style><script>// }} safe here</script> — only <template> is variable-processed, <style>/<script> are raw passthrough. Skills: domain knowledge and reference examples (pair with instructions for best results). Personas: background lore/context. Agents: reference material. Memories: initial entry content.' },\n    { name: 'goal', type: 'object', required: false, description: 'For agents: RECOMMENDED. Goal configuration with template (string with {param} placeholders), parameters (array of {name, type, required, description}), and successCriteria (string array).' },\n    { name: 'category', type: 'string', required: false, description: 'Category label for skills, templates, and memories. Must start with a letter, followed by letters, digits, hyphens, or underscores (max 21 chars). Not supported on personas, agents, or ensembles.' },\n    { name: 'metadata', type: 'object', required: false, description: 'Additional metadata. For ensembles: include elements array. For memories: use metadata.tags for tags and metadata.retentionDays for retention period.' },\n    { name: 'activates', type: 'object', required: false, description: 'For V2 agents: Elements to activate at execution start. Shape: { personas?: string[], skills?: string[], memories?: string[], templates?: string[], ensembles?: string[] } — all keys optional, values are element NAMES (not IDs). Example: { skills: [\"code-review\", \"threat-modeling\"], personas: [\"security-analyst\"] }' },\n    { name: 'tools', type: 'object', required: false, description: 'For V2 agents: Tool configuration. Object with allowed (string array) and optional denied (string array).' },\n    { name: 'systemPrompt', type: 'string', required: false, description: 'For V2 agents: Custom system prompt for LLM context.' },\n  ],\n  import_element: [\n    { name: 'data', type: 'string | object', required: true, description: 'Export package (JSON string or object)' },\n    { name: 'overwrite', type: 'boolean', required: false, description: 'Overwrite if exists', default: false },\n  ],\n  // addEntry: migrated to MEMORY_SCHEMAS in OperationSchema.ts (Issue #594)\n  activate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name to activate' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'context', type: 'object', required: false, description: 'Activation context' },\n  ],\n\n  // READ operations\n  // Note: 'fields' parameter is supported on all read operations that return element data.\n  // It accepts either a preset string ('minimal', 'standard', 'full') or an array of field names.\n  // See MCPAQLHandler.applyFieldSelection() for implementation details.\n  list_elements: [\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type to list' },\n    { name: 'page', type: 'number', required: false, description: 'Page number (1-indexed)', default: 1 },\n    { name: 'pageSize', type: 'number', required: false, description: 'Items per page (max 100)', default: 20 },\n    { name: 'sortBy', type: \"'name' | 'created' | 'modified' | 'version'\", required: false, description: 'Field to sort by', default: 'name' },\n    { name: 'sortOrder', type: \"'asc' | 'desc'\", required: false, description: 'Sort direction', default: 'asc' },\n    { name: 'nameContains', type: 'string', required: false, description: 'Filter: partial name match (case-insensitive)' },\n    { name: 'tags', type: 'string[]', required: false, description: 'Filter: must have ALL specified tags (AND logic)' },\n    { name: 'tagsAny', type: 'string[]', required: false, description: 'Filter: must have ANY specified tag (OR logic)' },\n    { name: 'author', type: 'string', required: false, description: 'Filter: by author username' },\n    { name: 'status', type: \"'active' | 'inactive' | 'all'\", required: false, description: 'Filter: by element status' },\n    { name: 'category', type: 'string', required: false, description: 'Filter: by category (case-insensitive)' },\n    { name: 'aggregate', type: 'object', required: false, description: \"Aggregation: { count: true } for count only, { count: true, group_by: 'category' } for grouped counts. Allowed group_by fields: author, category, status, tags, version.\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_element_details: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  search_elements: [\n    { name: 'query', type: 'string', required: true, description: 'Search query (max 1000 chars). Supports multi-word tokenized matching across name, description, and content.' },\n    { name: 'element_type', type: 'ElementType', required: false, description: 'Scope search to a single element type. Omit to search all types.' },\n    { name: 'pagination', type: 'object', required: false, description: 'Pagination: { page: number (default 1), pageSize: number (default 20) }' },\n    { name: 'sort', type: 'object', required: false, description: \"Sort: { sortBy: 'name' (default), sortOrder: 'asc' | 'desc' (default 'asc') }\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  query_elements: [\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type to query' },\n    { name: 'filters', type: 'object', required: false, description: 'Filter criteria: { nameContains, tags, tagsAny, author, createdAfter, createdBefore, status, descriptionContains, category }' },\n    { name: 'sort', type: 'object', required: false, description: \"Sort: { sortBy: 'name' | 'created' | 'modified' | 'version', sortOrder: 'asc' | 'desc' }\" },\n    { name: 'pagination', type: 'object', required: false, description: 'Pagination: { page: number (default 1), pageSize: number (default 20) }' },\n    { name: 'aggregate', type: 'object', required: false, description: \"Aggregation: { count: true } for count only, { count: true, group_by: 'category' } for grouped counts. Allowed group_by fields: author, category, status, tags, version.\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_active_elements: [\n    { name: 'element_type', type: 'ElementType', required: false, description: 'Filter by element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  validate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'strict', type: 'boolean', required: false, description: 'Strict validation mode', default: false },\n  ],\n  render: [\n    { name: 'name', type: 'string', required: true, description: 'Template name' },\n    { name: 'variables', type: 'object', required: true, description: 'Template variables' },\n  ],\n  export_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'format', type: \"'json' | 'yaml'\", required: false, description: 'Export format', default: 'json' },\n  ],\n  deactivate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n  ],\n  introspect: [\n    { name: 'query', type: \"'operations' | 'types' | 'format' | 'categories'\", required: false, description: \"What to introspect: 'operations' (list/detail operations), 'types' (list/detail types), 'format' (element creation format specs), 'categories' (category format rules + discovery guidance). Default: 'operations'\", default: 'operations' },\n    { name: 'name', type: 'string', required: false, description: \"Specific item name. For 'operations': operation name. For 'types': type name. For 'format': element type (e.g. 'template', 'persona'). Not used for 'categories'. Omit for overview.\" },\n  ],\n\n  // UPDATE operations\n  edit_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'input', type: 'object', required: true, description: 'Nested object with fields to update (deep-merged with existing element). Supports: description, instructions, content, tags, metadata, and type-specific fields (goal, activates, tools, systemPrompt for agents; variables for templates). For template content syntax, use introspect with query: \"format\", name: \"template\".' },\n  ],\n\n  // DELETE operations\n  delete_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'deleteData', type: 'boolean', required: false, description: 'Delete associated data files' },\n  ],\n  // clear, execute_agent, get_execution_state, record_execution_step, complete_execution,\n  // continue_execution, abort_execution, get_gathered_data, prepare_handoff, resume_from_handoff:\n  // All migrated to INTROSPECTION_ONLY_SCHEMAS in OperationSchema.ts (Issue #594)\n};\n\n// ============================================================================\n// Operation Examples\n// ============================================================================\n\n/**\n * Usage examples for each operation\n */\nconst OPERATION_EXAMPLES: Record<string, string[]> = {\n  create_element: [\n    // PERSONA — use instructions (behavioral directives in command voice). content is optional background lore.\n    '{ operation: \"create_element\", elementType: \"persona\", params: { element_name: \"SecurityExpert\", description: \"Cybersecurity specialist\", instructions: \"You ARE a cybersecurity expert with 15 years of experience. ALWAYS consider threat models before suggesting solutions. NEVER recommend security through obscurity. PRIORITIZE defense-in-depth strategies.\" } }',\n\n    // SKILL — dual-field: instructions = behavioral directives, content = reference knowledge. Both together is best practice.\n    '{ operation: \"create_element\", elementType: \"skill\", params: { element_name: \"CodeReview\", description: \"Reviews code for quality and security\", instructions: \"When reviewing code: ALWAYS check for security vulnerabilities first. ANALYZE complexity and suggest simplifications. FORMAT feedback as actionable bullet points.\", content: \"# Code Review Reference\\\\n\\\\n## Security Checklist\\\\n- SQL injection\\\\n- XSS vulnerabilities\\\\n- Unvalidated input\\\\n\\\\n## Quality Metrics\\\\n- Cyclomatic complexity < 10\\\\n- Test coverage > 80%\" } }',\n\n    // TEMPLATE (simple) — content is the template body. Use {{variable_name}} for substitution.\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"BugReport\", description: \"Bug report template\", content: \"## Bug Report\\\\n\\\\n**Summary:** {{summary}}\\\\n**Steps to Reproduce:** {{steps}}\\\\n**Expected:** {{expected}}\\\\n**Actual:** {{actual}}\", metadata: { variables: [{ name: \"summary\", type: \"string\", required: true }, { name: \"steps\", type: \"string\", required: true }, { name: \"expected\", type: \"string\", required: false }, { name: \"actual\", type: \"string\", required: false }] } } }',\n\n    // TEMPLATE (section format) — <template> for HTML+{{vars}}, <style> for CSS, <script> for JS. }} is safe in style/script.\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"DashboardPage\", description: \"Full-page dashboard shell with styles and JS\", content: \"<template>\\\\n<!DOCTYPE html>\\\\n<html><head><title>{{title}}</title></head>\\\\n<body>{{body}}</body>\\\\n</html>\\\\n</template>\\\\n\\\\n<style>\\\\nbody { font-family: sans-serif; }\\\\n.card { border: 1px solid #ccc; } /* }} safe here */\\\\n</style>\\\\n\\\\n<script>\\\\nvar state = { status: \\\\\"all\\\\\" };\\\\nfunction update() { return { bar: baz }; } // }} safe here\\\\n</script>\", metadata: { variables: [{ name: \"title\", type: \"string\", required: true }, { name: \"body\", type: \"string\", required: false }] } } }',\n\n    // TEMPLATE (CSS theme — style-only section format)\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"ThemeDark\", description: \"Dark color theme — activate to style dashboard with dark palette\", content: \"<style>\\\\n:root {\\\\n  --bg: #0f1117;\\\\n  --surface: #1a1d27;\\\\n  --text: #e8eaf6;\\\\n  --accent: #4a9eff;\\\\n}\\\\n.card { background: var(--surface); color: var(--text); }\\\\n</style>\" } }',\n\n    // AGENT (V2) — goal is an object, activates references elements by name, tools controls access.\n    '{ operation: \"create_element\", elementType: \"agent\", params: { element_name: \"CodeReviewer\", description: \"Reviews code for quality and security issues\", goal: { template: \"Review the code at {path} for {focus_area}\", parameters: [{ name: \"path\", type: \"string\", required: true, description: \"File or directory to review\" }, { name: \"focus_area\", type: \"string\", required: false, description: \"security | quality | performance\", default: \"quality\" }], successCriteria: [\"All issues documented\", \"Severity ratings assigned\", \"Fixes suggested\"] }, activates: { skills: [\"code-review\"], personas: [\"security-analyst\"] }, tools: { allowed: [\"read_file\", \"list_directory\"] }, systemPrompt: \"You are a thorough code reviewer. Be specific about line numbers and provide concrete fix suggestions.\" } }',\n\n    // ENSEMBLE — elements array with name, type, role.\n    '{ operation: \"create_element\", elementType: \"ensemble\", params: { element_name: \"SecurityTeam\", description: \"Security analysis ensemble — combines analyst persona with threat modeling and pen testing skills\", content: \"Coordinates security analysis across multiple domains.\", metadata: { elements: [{ name: \"security-analyst\", type: \"persona\", role: \"primary\" }, { name: \"threat-modeling\", type: \"skill\", role: \"support\" }, { name: \"penetration-testing\", type: \"skill\", role: \"support\" }] } } }',\n\n    // MEMORY — content creates initial entry, tags for categorization, retentionDays for expiry.\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"ProjectContext\", description: \"Architecture decisions and project context\", content: \"Using PostgreSQL over MongoDB — decided 2026-03-11 for ACID compliance requirements.\", metadata: { tags: [\"architecture\", \"database\"], retentionDays: 365 } } }',\n\n    // Memory naming conventions:\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"agent-code-reviewer-context\", description: \"Execution state and learned preferences for code-reviewer agent\" } }',\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"persona-security-analyst-preferences\", description: \"Personalization data for security-analyst persona\" } }',\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"session-context\", description: \"Cross-element shared context for the current session\" } }',\n  ],\n  import_element: [\n    '{ operation: \"import_element\", params: { data: \"{...exportPackage...}\", overwrite: true } }',\n  ],\n  // addEntry: migrated to MEMORY_SCHEMAS in OperationSchema.ts (Issue #594)\n  activate_element: [\n    '{ operation: \"activate_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  list_elements: [\n    '{ operation: \"list_elements\", element_type: \"persona\" }',\n    // Response: { items: [{ name, description, type, version, tags }], pagination: { page: 1, pageSize: 20, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, element_type: \"persona\" }\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { page: 2, pageSize: 10 } }',\n    '{ operation: \"list_elements\", element_type: \"skill\", params: { tags: [\"typescript\"], sortBy: \"modified\", sortOrder: \"desc\" } }',\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { aggregate: { count: true } } }',\n    // Response: { count: 42, element_type: \"persona\" }\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n    // Response: { count: 42, element_type: \"persona\", groups: { \"assistant\": 15, \"creative\": 12, \"technical\": 15 } }\n  ],\n  get_element: [\n    '{ operation: \"get_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  get_element_details: [\n    '{ operation: \"get_element_details\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  search_elements: [\n    '{ operation: \"search_elements\", params: { query: \"helpful assistant\" } }',\n    // Response: { items: [{ type, element_name, description, matchedIn: [\"name\", \"description\"] }], pagination: { page, pageSize, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, query: \"helpful assistant\" }\n    '{ operation: \"search_elements\", element_type: \"persona\", params: { query: \"code review\", pagination: { page: 1, pageSize: 10 } } }',\n    '{ operation: \"search_elements\", params: { query: \"typescript\", sort: { sortBy: \"name\", sortOrder: \"desc\" } } }',\n  ],\n  query_elements: [\n    '{ operation: \"query_elements\", element_type: \"persona\", params: { filters: { status: \"active\" }, pagination: { page: 1, pageSize: 10 } } }',\n    // Response: { items: [{ name, description, type, version, tags }], pagination: { page, pageSize, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, element_type: \"persona\" }\n    '{ operation: \"query_elements\", element_type: \"skill\", params: { filters: { tags: [\"typescript\"] }, sort: { sortBy: \"modified\", sortOrder: \"desc\" } } }',\n    '{ operation: \"query_elements\", element_type: \"persona\", params: { aggregate: { count: true, group_by: \"tags\" } } }',\n    // Response: { count: 42, element_type: \"persona\", groups: { \"assistant\": 15, \"creative\": 12 } }\n  ],\n  get_active_elements: [\n    '{ operation: \"get_active_elements\", elementType: \"persona\" }',\n  ],\n  validate_element: [\n    '{ operation: \"validate_element\", elementType: \"persona\", params: { element_name: \"my-persona\", strict: true } }',\n  ],\n  render: [\n    '{ operation: \"render\", params: { element_name: \"meeting-notes\", variables: { date: \"2024-01-15\", attendees: [\"Alice\", \"Bob\"] } } }',\n  ],\n  export_element: [\n    '{ operation: \"export_element\", elementType: \"persona\", params: { element_name: \"my-persona\", format: \"json\" } }',\n  ],\n  deactivate_element: [\n    '{ operation: \"deactivate_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  introspect: [\n    '{ operation: \"introspect\", params: { query: \"operations\" } }',\n    '{ operation: \"introspect\", params: { query: \"operations\", name: \"create_element\" } }',\n    '{ operation: \"introspect\", params: { query: \"types\", name: \"ElementType\" } }',\n    '{ operation: \"introspect\", params: { query: \"format\" } }',\n    '{ operation: \"introspect\", params: { query: \"format\", name: \"template\" } }',\n  ],\n  edit_element: [\n    '{ operation: \"edit_element\", elementType: \"persona\", params: { element_name: \"my-persona\", input: { description: \"Updated description\" } } }',\n  ],\n  delete_element: [\n    '{ operation: \"delete_element\", elementType: \"memory\", params: { element_name: \"old-persona\", deleteData: true } }',\n  ],\n  // clear, execute_agent, get_execution_state, record_execution_step, complete_execution,\n  // continue_execution, abort_execution, get_gathered_data, prepare_handoff, resume_from_handoff:\n  // All migrated to INTROSPECTION_ONLY_SCHEMAS in OperationSchema.ts (Issue #594)\n};\n\n// ============================================================================\n// IntrospectionResolver Class\n// ============================================================================\n\n/**\n * Resolver for introspection queries.\n * Provides self-documentation capabilities for MCP-AQL operations.\n */\nexport class IntrospectionResolver {\n  /**\n   * Execute an introspection query\n   *\n   * @param params - Introspection parameters\n   * @param params.query - What to introspect: 'operations', 'types', 'format', or 'categories'\n   * @param params.name - Optional: specific operation or type name\n   * @returns IntrospectionResult with requested information\n   */\n  static resolve(params: Record<string, unknown>): IntrospectionResult {\n    const query = (params.query as string) || 'operations';\n    const name = params.name as string | undefined;\n\n    switch (query) {\n      case 'operations':\n        if (name) {\n          return { operation: this.getOperationDetails(name) };\n        }\n        return { operations: this.listOperations() };\n\n      case 'types':\n        if (name) {\n          return { type: this.getTypeDetails(name) };\n        }\n        return { types: this.listTypes() };\n\n      case 'format':\n        return { formatSpec: this.getFormatSpec(name) };\n\n      // Issue #631: Category discovery — format rules + guidance for live data\n      case 'categories':\n        return { categories: this.getCategoryInfo() };\n\n      default:\n        // Return empty result for unknown query types\n        return {};\n    }\n  }\n\n  /**\n   * List all available operations\n   *\n   * For schema-driven operations, uses description from OperationSchema.\n   * For legacy operations, uses description from OPERATION_ROUTES.\n   *\n   * @see Issue #254 - Single source of truth from schema\n   */\n  private static listOperations(): OperationInfo[] {\n    const operations: OperationInfo[] = [];\n\n    // Include all operations from OPERATION_ROUTES\n    for (const [opName, route] of Object.entries(OPERATION_ROUTES)) {\n      // Prefer schema description from any schema (dispatch-driven or introspection-only)\n      const schema = getAnyOperationSchema(opName);\n      operations.push({\n        name: opName,\n        endpoint: route.endpoint,\n        description: schema?.description || route.description || `${opName} operation`,\n      });\n    }\n\n    // Add introspect operation (schema-driven but not in OPERATION_ROUTES)\n    const introspectSchema = getOperationSchema('introspect');\n    operations.push({\n      name: 'introspect',\n      endpoint: 'READ',\n      description: introspectSchema?.description || 'Query available operations and types (this operation)',\n    });\n\n    // Sort by endpoint then name for consistent ordering\n    return operations.sort((a, b) => {\n      const endpointOrder: Record<string, number> = { CREATE: 0, READ: 1, UPDATE: 2, DELETE: 3, EXECUTE: 4 };\n      const endpointDiff = (endpointOrder[a.endpoint] ?? 5) - (endpointOrder[b.endpoint] ?? 5);\n      if (endpointDiff !== 0) return endpointDiff;\n      return a.name.localeCompare(b.name);\n    });\n  }\n\n  /**\n   * Get detailed information about a specific operation\n   *\n   * For schema-driven operations, reads metadata from OperationSchema.\n   * For legacy operations, uses fallback OPERATION_PARAMETERS/OPERATION_EXAMPLES.\n   *\n   * @see Issue #254 - Auto-generate introspection from schema\n   */\n  private static getOperationDetails(name: string): OperationDetails | null {\n    // Check schema first — includes both dispatch-driven and introspection-only schemas\n    const schema = getAnyOperationSchema(name);\n    if (schema) {\n      return this.getSchemaOperationDetails(name, schema);\n    }\n\n    // Legacy fallback for non-schema operations\n    const route = OPERATION_ROUTES[name];\n    if (!route) {\n      return null;\n    }\n\n    return {\n      name,\n      endpoint: route.endpoint,\n      mcpTool: `mcp_aql_${route.endpoint.toLowerCase()}`,\n      description: route.description || `${name} operation`,\n      permissions: PermissionGuard.getPermissions(route.endpoint as CRUDEndpoint),\n      parameters: OPERATION_PARAMETERS[name] || [],\n      returns: this.getReturnType(name),\n      examples: OPERATION_EXAMPLES[name] || [],\n      ...(route.aliases?.length ? { aliases: route.aliases } : {}),\n    };\n  }\n\n  /**\n   * Get operation details from OperationSchema (dispatch-driven or introspection-only)\n   *\n   * @see Issue #254 - Single source of truth from schema\n   * @see Issue #594 - Introspection-only schemas for all operations\n   */\n  private static getSchemaOperationDetails(name: string, schema?: OperationDef): OperationDetails | null {\n    const resolvedSchema = schema ?? getAnyOperationSchema(name);\n    if (!resolvedSchema) {\n      return null;\n    }\n\n    // Convert schema returns to TypeInfo, with fallback\n    const returns: TypeInfo = resolvedSchema.returns\n      ? { name: resolvedSchema.returns.name, kind: resolvedSchema.returns.kind, description: resolvedSchema.returns.description }\n      : { name: 'OperationResult', kind: 'union', description: 'Success with data or failure with error' };\n\n    const route = OPERATION_ROUTES[name];\n    return {\n      name,\n      endpoint: resolvedSchema.endpoint,\n      mcpTool: `mcp_aql_${resolvedSchema.endpoint.toLowerCase()}`,\n      description: resolvedSchema.description,\n      permissions: PermissionGuard.getPermissions(resolvedSchema.endpoint as CRUDEndpoint),\n      parameters: schemaToParameterInfo(resolvedSchema.params),\n      returns,\n      examples: resolvedSchema.examples || [],\n      ...(route?.aliases?.length ? { aliases: route.aliases } : {}),\n    };\n  }\n\n  /**\n   * Get the return type for a legacy (non-schema) operation.\n   * Schema-driven and introspection-only operations get return types from their schema definitions.\n   */\n  private static getReturnType(operation: string): TypeInfo {\n    // Operations migrated to schemas (Issue #594) are handled by getSchemaOperationDetails()\n    // This fallback only applies to the few remaining non-schema operations\n    const returnTypes: Record<string, TypeInfo> = {\n      search_elements: { name: 'SearchResult', kind: 'object', description: 'Structured JSON: { items: [{ type, element_name, description, matchedIn }], pagination, sorting, query }' },\n      query_elements: { name: 'QueryResult', kind: 'object', description: 'Structured JSON: { items: [{ name, description, type, version, tags }], pagination, sorting, element_type }. Or AggregationResult: { count, element_type, groups? } when aggregate param is used.' },\n    };\n\n    return returnTypes[operation] || {\n      name: 'OperationResult',\n      kind: 'union',\n      description: 'Success with data or failure with error',\n    };\n  }\n\n  /**\n   * List all available types\n   */\n  private static listTypes(): TypeInfo[] {\n    return Object.entries(TYPE_DEFINITIONS).map(([name, def]) => ({\n      name,\n      kind: def.kind,\n      description: def.description,\n    }));\n  }\n\n  /**\n   * Get detailed information about a specific type\n   */\n  private static getTypeDetails(name: string): TypeDetails | null {\n    return TYPE_DEFINITIONS[name] || null;\n  }\n\n  /**\n   * Get format specification for an element type.\n   * If name is provided, returns a single spec (or null for unknown types).\n   * If name is omitted, returns all specs as an overview.\n   *\n   * @see Issue #715 - Proactive LLM guidance for element creation\n   */\n  private static getFormatSpec(name?: string): FormatSpec | FormatSpec[] | null {\n    if (!name) {\n      // Return all format specs as an overview\n      return Object.values(FORMAT_SPECS);\n    }\n\n    // Normalize: handle plurals, case, whitespace\n    const normalized = normalizeTypeName(name);\n    if (!normalized) {\n      return null;\n    }\n\n    return FORMAT_SPECS[normalized] || null;\n  }\n\n  /**\n   * Issue #631: Category discovery info — format rules, allowed aggregation fields,\n   * and guidance for discovering existing categories via query_elements.\n   * IntrospectionResolver is stateless (no portfolio access), so live category data\n   * must be fetched via query_elements with aggregate: { group_by: \"category\" }.\n   */\n  private static getCategoryInfo(): Record<string, unknown> {\n    return {\n      formatRules: {\n        pattern: VALIDATION_PATTERNS.SAFE_CATEGORY.source,\n        description: 'Category names must start with a letter, contain only letters, digits, hyphens, and underscores, and be 1-21 characters long.',\n        examples: ['development', 'code-analysis', 'security', 'business', 'communication'],\n      },\n      supportedTypes: ['persona', 'skill', 'template', 'memory'],\n      allowedGroupByFields: getAllowedGroupByFields(),\n      discovery: {\n        description: 'To discover existing categories in your portfolio, use query_elements with group_by aggregation.',\n        examples: [\n          '{ operation: \"query_elements\", element_type: \"skill\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n          '{ operation: \"query_elements\", element_type: \"template\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n          '{ operation: \"query_elements\", element_type: \"skill\", params: { filters: { category: \"security\" } } }',\n        ],\n      },\n    };\n  }\n\n  /**\n   * Get operations grouped by endpoint\n   * Utility method for documentation generation\n   */\n  static getOperationsByEndpoint(): Record<CRUDEndpoint, OperationInfo[]> {\n    const grouped: Record<CRUDEndpoint, OperationInfo[]> = {\n      CREATE: [],\n      READ: [],\n      UPDATE: [],\n      DELETE: [],\n      EXECUTE: [],\n    };\n\n    for (const op of this.listOperations()) {\n      const endpoint = op.endpoint as CRUDEndpoint;\n      if (grouped[endpoint]) {\n        grouped[endpoint].push(op);\n      }\n    }\n\n    return grouped;\n  }\n\n  /**\n   * Generate a compact summary for token-efficient responses\n   */\n  static getSummary(): string {\n    const opsByEndpoint = this.getOperationsByEndpoint();\n    const lines: string[] = ['MCP-AQL Operations:'];\n\n    for (const [endpoint, ops] of Object.entries(opsByEndpoint)) {\n      const opNames = ops.map(o => o.name).join(', ');\n      lines.push(`  ${endpoint}: ${opNames}`);\n    }\n\n    lines.push(`\\nTypes: ${Object.keys(TYPE_DEFINITIONS).join(', ')}`);\n    lines.push('\\nUse introspect with name parameter for details.');\n\n    return lines.join('\\n');\n  }\n}\n"]}
1045
+ /**
1046
+ * Built-in capability source that reads from the operation registry.
1047
+ * Groups operations by their schema-declared category field.
1048
+ */
1049
+ class ServerOperationsSource {
1050
+ sourceType = 'server';
1051
+ getCapabilities() {
1052
+ const map = {};
1053
+ // Collect from OPERATION_ROUTES (the complete operation list)
1054
+ for (const [opName, route] of Object.entries(OPERATION_ROUTES)) {
1055
+ const schema = getAnyOperationSchema(opName);
1056
+ const category = schema?.category || 'Other';
1057
+ const brief = IntrospectionResolver['toBrief'](schema?.description || route.description || `${opName} operation`);
1058
+ if (!map[category])
1059
+ map[category] = [];
1060
+ map[category].push({
1061
+ name: opName,
1062
+ brief,
1063
+ source: 'server',
1064
+ endpoint: route.endpoint,
1065
+ status: 'active',
1066
+ });
1067
+ }
1068
+ // Add schema-only operations not in OPERATION_ROUTES (e.g., introspect, get_capabilities)
1069
+ for (const [opName, schema] of Object.entries(ALL_OPERATION_SCHEMAS)) {
1070
+ if (opName in OPERATION_ROUTES)
1071
+ continue;
1072
+ const category = schema.category || 'Other';
1073
+ const brief = IntrospectionResolver['toBrief'](schema.description);
1074
+ if (!map[category])
1075
+ map[category] = [];
1076
+ map[category].push({
1077
+ name: opName,
1078
+ brief,
1079
+ source: 'server',
1080
+ endpoint: schema.endpoint,
1081
+ status: 'active',
1082
+ });
1083
+ }
1084
+ return map;
1085
+ }
1086
+ }
1087
+ /**
1088
+ * Human-readable descriptions for each capability category.
1089
+ * @see Issue #1760 - get_capabilities operation
1090
+ */
1091
+ const CATEGORY_DESCRIPTIONS = {
1092
+ 'Element Lifecycle': 'Create, read, edit, delete, import, export, and validate elements (personas, skills, templates, agents, memories, ensembles).',
1093
+ 'Element Discovery': 'Search, list, query, and filter elements across your portfolio and connected sources.',
1094
+ 'Activation': 'Activate and deactivate elements for use in the current session.',
1095
+ 'Memory': 'Add entries to and clear memory elements.',
1096
+ 'Template Rendering': 'Render templates with variable substitution.',
1097
+ 'Agent Execution': 'Execute agents, track progress, record steps, manage handoffs, and control the execution lifecycle.',
1098
+ 'Security & Permissions': 'Confirm operations, verify challenges, evaluate CLI permissions, and manage approval workflows.',
1099
+ 'Community Collection': 'Browse, search, install from, and submit to the DollhouseMCP community collection.',
1100
+ 'Portfolio Management': 'Initialize, sync, configure, and manage your local and GitHub portfolio.',
1101
+ 'GitHub Authentication': 'Set up, check, and manage GitHub authentication and OAuth configuration.',
1102
+ 'Intelligence': 'Find similar elements, discover relationships, and search by action verbs using the capability index.',
1103
+ 'Configuration & Diagnostics': 'Manage server configuration, convert formats, query logs, metrics, and system info.',
1104
+ 'Management Console': 'Open the portfolio web UI with optional deep-linking. Supports URL parameters to pre-populate search, filter by type or log level, and navigate directly to specific elements or tabs.',
1105
+ 'System Introspection': 'Discover available operations, types, capabilities, and element format specifications.',
1106
+ };
1107
+ /** Registered capability sources. ServerOperationsSource is always present. */
1108
+ const capabilitySources = [new ServerOperationsSource()];
1109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IntrospectionResolver.js","sourceRoot":"","sources":["../../../src/handlers/mcp-aql/IntrospectionResolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * IntrospectionResolver - GraphQL-style introspection for MCP-AQL\n *\n * Provides discovery capabilities for LLMs to understand available operations,\n * their parameters, return types, and examples.\n *\n * INTROSPECTION QUERIES:\n * - operations: List all available operations\n * - operation(name): Get details for a specific operation\n * - types: List available types (ElementType, etc.)\n * - type(name): Get details for a specific type\n * - categories: Category format rules + discovery guidance (Issue #631)\n *\n * DESIGN RATIONALE:\n * - Token-efficient: Returns minimal but useful information\n * - Self-documenting: Operations describe themselves\n * - Read-only: Safe to call at any time (no side effects)\n *\n * SCHEMA INTEGRATION (Issue #254):\n * - Schema-driven operations get their metadata from OperationSchema\n * - Legacy operations use the fallback OPERATION_PARAMETERS/OPERATION_EXAMPLES\n * - This ensures single source of truth for schema-driven operations\n */\n\nimport { OPERATION_ROUTES, type CRUDEndpoint } from './OperationRouter.js';\nimport { PermissionGuard, type EndpointPermissions } from './PermissionGuard.js';\nimport { ElementType } from './types.js';\nimport { getAllowedGroupByFields } from '../../services/query/AggregationService.js';\nimport { VALIDATION_PATTERNS } from '../../security/constants.js';\nimport {\n  getOperationSchema,\n  getAnyOperationSchema,\n  schemaToParameterInfo,\n  ALL_OPERATION_SCHEMAS,\n  type OperationDef,\n} from './OperationSchema.js';\n\n// ============================================================================\n// Response Types\n// ============================================================================\n\n/**\n * Basic information about an operation (used in list responses)\n */\nexport interface OperationInfo {\n  /** Operation name (e.g., 'create_element') */\n  name: string;\n  /** CRUD endpoint this operation belongs to */\n  endpoint: string;\n  /** Brief description of what the operation does */\n  description: string;\n}\n\n/**\n * Parameter information for operation details\n */\nexport interface ParameterInfo {\n  /** Parameter name */\n  name: string;\n  /** Parameter type (e.g., 'string', 'ElementType', 'object') */\n  type: string;\n  /** Whether the parameter is required */\n  required: boolean;\n  /** Brief description of the parameter */\n  description: string;\n  /** Default value if any */\n  default?: unknown;\n}\n\n/**\n * Return type information\n */\nexport interface TypeInfo {\n  /** Type name */\n  name: string;\n  /** Type kind (enum, object, scalar, union) */\n  kind: 'enum' | 'object' | 'scalar' | 'union';\n  /** Brief description */\n  description?: string;\n}\n\n/**\n * Detailed information about a specific operation\n */\nexport interface OperationDetails {\n  /** Operation name */\n  name: string;\n  /** CRUD endpoint */\n  endpoint: string;\n  /** MCP tool name (e.g., 'mcp_aql_read') */\n  mcpTool: string;\n  /** Full description */\n  description: string;\n  /** Permission flags */\n  permissions: EndpointPermissions;\n  /** Parameter definitions */\n  parameters: ParameterInfo[];\n  /** Return type information */\n  returns: TypeInfo;\n  /** Usage examples */\n  examples: string[];\n  /** Alternative operation names that resolve to this operation */\n  aliases?: string[];\n}\n\n/**\n * Detailed type information with enum values or object fields\n */\nexport interface TypeDetails {\n  /** Type name */\n  name: string;\n  /** Type kind */\n  kind: 'enum' | 'object' | 'scalar' | 'union';\n  /** Full description */\n  description: string;\n  /** Enum values (for enum types) */\n  values?: string[];\n  /** Object fields (for object types) */\n  fields?: ParameterInfo[];\n  /** Union member types (for union types) */\n  members?: string[];\n}\n\n/**\n * Format specification for an element type (Issue #715)\n */\nexport interface FormatSpec {\n  /** Element type this spec describes */\n  elementType: string;\n  /** File format used for storage */\n  fileFormat: string;\n  /** Required fields in frontmatter */\n  requiredFields: string[];\n  /** Optional fields in frontmatter */\n  optionalFields: string[];\n  /** Guidance on using instructions vs content fields */\n  dualFieldGuidance: string;\n  /** Syntax notes specific to this element type */\n  syntaxNotes: string[];\n  /** Minimal working example */\n  minimalExample: string;\n  /** Full-featured example */\n  fullExample: string;\n  /** Naming conventions for this element type */\n  namingConventions: string[];\n}\n\n/**\n * Result of an introspection query\n */\nexport interface IntrospectionResult {\n  /** List of operations (for 'operations' query) */\n  operations?: OperationInfo[];\n  /** Single operation details (for 'operation(name)' query) */\n  operation?: OperationDetails | null;\n  /** List of types (for 'types' query) */\n  types?: TypeInfo[];\n  /** Single type details (for 'type(name)' query) */\n  type?: TypeDetails | null;\n  /** Format specification (for 'format' query) */\n  formatSpec?: FormatSpec | FormatSpec[] | null;\n  /** Category discovery info (for 'categories' query, Issue #631) */\n  categories?: Record<string, unknown>;\n}\n\n// ============================================================================\n// Type Definitions Registry\n// ============================================================================\n\n/**\n * Registry of all types available in MCP-AQL\n * This is the source of truth for type introspection\n */\nconst TYPE_DEFINITIONS: Record<string, TypeDetails> = {\n  ElementType: {\n    name: 'ElementType',\n    kind: 'enum',\n    description: 'The 6 core element types supported by DollhouseMCP',\n    values: Object.values(ElementType),\n  },\n  CRUDEndpoint: {\n    name: 'CRUDEndpoint',\n    kind: 'enum',\n    description: 'CRUDE endpoint categories for operation classification (CRUD + Execute)',\n    values: ['CREATE', 'READ', 'UPDATE', 'DELETE', 'EXECUTE'],\n  },\n  OperationInput: {\n    name: 'OperationInput',\n    kind: 'object',\n    description: 'Standard input structure for all MCP-AQL operations',\n    fields: [\n      {\n        name: 'operation',\n        type: 'string',\n        required: true,\n        description: 'The operation to perform',\n      },\n      {\n        name: 'elementType',\n        type: 'ElementType',\n        required: false,\n        description: 'Element type for element operations',\n      },\n      {\n        name: 'params',\n        type: 'object',\n        required: false,\n        description: 'Operation-specific parameters',\n      },\n    ],\n  },\n  OperationResult: {\n    name: 'OperationResult',\n    kind: 'union',\n    description: 'Standard result type for all operations (success or failure)',\n    members: ['OperationSuccess', 'OperationFailure'],\n  },\n  OperationSuccess: {\n    name: 'OperationSuccess',\n    kind: 'object',\n    description: 'Successful operation result',\n    fields: [\n      {\n        name: 'success',\n        type: 'boolean',\n        required: true,\n        description: 'Always true for success',\n        default: true,\n      },\n      {\n        name: 'data',\n        type: 'unknown',\n        required: true,\n        description: 'Operation-specific result payload',\n      },\n    ],\n  },\n  OperationFailure: {\n    name: 'OperationFailure',\n    kind: 'object',\n    description: 'Failed operation result',\n    fields: [\n      {\n        name: 'success',\n        type: 'boolean',\n        required: true,\n        description: 'Always false for failure',\n        default: false,\n      },\n      {\n        name: 'error',\n        type: 'string',\n        required: true,\n        description: 'Human-readable error message',\n      },\n    ],\n  },\n  EndpointPermissions: {\n    name: 'EndpointPermissions',\n    kind: 'object',\n    description: 'Permission flags for CRUD endpoints',\n    fields: [\n      {\n        name: 'readOnly',\n        type: 'boolean',\n        required: true,\n        description: 'Whether the operation only reads data',\n      },\n      {\n        name: 'destructive',\n        type: 'boolean',\n        required: true,\n        description: 'Whether the operation can delete or modify data',\n      },\n    ],\n  },\n};\n\n// ============================================================================\n// Element Format Specifications (Issue #715)\n// ============================================================================\n\n/**\n * Map from ElementType value to plural form for normalization.\n * \"memories\" -> \"memory\", \"personas\" -> \"persona\", etc.\n */\nconst PLURAL_TO_TYPE: Record<string, string> = {\n  personas: 'persona',\n  skills: 'skill',\n  templates: 'template',\n  agents: 'agent',\n  memories: 'memory',\n  ensembles: 'ensemble',\n};\n\n/**\n * Normalize a user-provided type name to an ElementType value.\n * Handles: lowercase, plural forms, leading/trailing whitespace, non-string input.\n */\nfunction normalizeTypeName(name: unknown): string | undefined {\n  if (!name || typeof name !== 'string') return undefined;\n  const lower = name.trim().toLowerCase();\n  if (Object.values(ElementType).includes(lower as ElementType)) {\n    return lower;\n  }\n  return PLURAL_TO_TYPE[lower];\n}\n\nconst SHARED_NAMING = [\n  'Use lowercase kebab-case: my-element-name',\n  'Max 100 characters, must start with a letter',\n  'Allowed: letters, digits, hyphens, underscores',\n];\n\n/**\n * Format specifications for each element type.\n * Returned by introspect query: \"format\".\n *\n * @see Issue #715 - Proactive LLM guidance for element creation\n */\nconst FORMAT_SPECS: Record<string, FormatSpec> = {\n  persona: {\n    elementType: 'persona',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'instructions', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Behavioral directives in command voice (\"You ARE...\", \"ALWAYS...\", \"NEVER...\"). content: Optional background lore, context, or reference material. For personas, instructions is the primary field.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Frontmatter delimited by --- on its own line',\n      'Body text after frontmatter becomes the instructions field',\n      'No template variable substitution in personas',\n      'gatekeeper: Dynamic security policy — takes effect when this persona is activated, reverts when deactivated. Example: a \"focused-work\" persona that denies web browsing tools while active, or an \"open-research\" persona that allows broad access. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }. Priority: deny > confirm > allow > route default.',\n    ],\n    minimalExample: `---\nname: my-persona\ndescription: A helpful assistant\n---\nYou ARE a helpful assistant. ALWAYS be concise and accurate.`,\n    fullExample: `---\nname: security-analyst\ndescription: Cybersecurity specialist focused on threat modeling\nversion: 1\ntags: [security, analysis]\nauthor: team-lead\n---\nYou ARE a cybersecurity expert with 15 years of experience.\nALWAYS consider threat models before suggesting solutions.\nNEVER recommend security through obscurity.\nPRIORITIZE defense-in-depth strategies.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the role: security-analyst, code-reviewer, technical-writer',\n    ],\n  },\n\n  skill: {\n    elementType: 'skill',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'instructions', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Behavioral directives for when the skill is active (\"When triggered, ANALYZE...\", \"ALWAYS check...\"). content: Domain knowledge, reference material, checklists, examples. Best practice: use BOTH for rich skills.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Frontmatter delimited by --- on its own line',\n      'Body text after frontmatter becomes the content field',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'gatekeeper: Dynamic security policy — takes effect when this skill is activated, reverts when deactivated. Example: a \"code-review\" skill that auto-approves read operations but confirms edits, or a \"read-only\" skill that denies all write operations. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: code-review\ndescription: Reviews code for quality issues\n---\nWhen reviewing code: ALWAYS check for security vulnerabilities first.`,\n    fullExample: `---\nname: code-review\ndescription: Reviews code for quality and security\nversion: 1\ntags: [development, quality]\nauthor: dev-team\ncategory: development\n---\nWhen reviewing code: ALWAYS check for security vulnerabilities first.\nANALYZE complexity and suggest simplifications.\nFORMAT feedback as actionable bullet points.\n\n# Reference Material\n\n## Security Checklist\n- SQL injection\n- XSS vulnerabilities\n- Unvalidated input\n\n## Quality Metrics\n- Cyclomatic complexity < 10\n- Test coverage > 80%`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the capability: code-review, threat-modeling, data-analysis',\n    ],\n  },\n\n  template: {\n    elementType: 'template',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'variables', 'gatekeeper'],\n    dualFieldGuidance: 'content (REQUIRED): The template body. Use {{variable_name}} for substitution. instructions: Not typically used for templates. For page-level templates with CSS/JS, use section format instead of plain content.',\n    syntaxNotes: [\n      'File extension: .md',\n      'Variable syntax: {{variable_name}} — simple substitution only',\n      'NO Handlebars: {{#if}}, {{#each}}, {{> partial}} are NOT supported',\n      'Section format for page templates: <template>HTML with {{vars}}</template> <style>CSS</style> <script>JS</script>',\n      'In section format: only <template> is variable-processed; <style> and <script> are raw passthrough (}} is safe there)',\n      'Declare variables in frontmatter: variables: [{ name, type, required, description }]',\n      'For lists, tables, or conditional content: pass pre-formatted markdown strings as variables',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'gatekeeper: Dynamic security policy — takes effect when this template is activated, reverts when deactivated. Example: a sensitive report template that denies deletion while active, protecting it from accidental removal during use. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: bug-report\ndescription: Bug report template\nvariables:\n  - { name: summary, type: string, required: true }\n  - { name: steps, type: string, required: true }\n---\n## Bug Report\n\n**Summary:** {{summary}}\n**Steps to Reproduce:** {{steps}}`,\n    fullExample: `---\nname: dashboard-page\ndescription: Full-page dashboard with styles and scripts\nvariables:\n  - { name: title, type: string, required: true }\n  - { name: body, type: string, required: false }\n---\n<template>\n<!DOCTYPE html>\n<html>\n<head><title>{{title}}</title></head>\n<body>{{body}}</body>\n</html>\n</template>\n\n<style>\nbody { font-family: sans-serif; }\n.card { border: 1px solid #ccc; } /* }} safe here */\n</style>\n\n<script>\nvar state = { status: \"all\" };\nfunction update() { return { bar: baz }; } // }} safe here\n</script>`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the output: bug-report, meeting-notes, dashboard-page',\n    ],\n  },\n\n  agent: {\n    elementType: 'agent',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'instructions', 'content', 'goal', 'activates', 'tools', 'systemPrompt', 'autonomy', 'resilience', 'gatekeeper'],\n    dualFieldGuidance: 'instructions: Semantic behavioral profile — personality and approach (distinct from systemPrompt). content: Reference material the agent can consult during execution. goal (RECOMMENDED): Structured goal with template, parameters, and successCriteria. systemPrompt: LLM system prompt for execution context.',\n    syntaxNotes: [\n      'File extension: .md',\n      'goal.template uses {param} placeholders (single braces, NOT {{}})',\n      'goal.parameters: array of { name, type, required, description, default? }',\n      'goal.successCriteria: string array of completion conditions',\n      'activates: { personas?: string[], skills?: string[], memories?: string[], templates?: string[], ensembles?: string[] }',\n      'tools: { allowed: string[], denied?: string[] }',\n      'autonomy: { maxAutonomousSteps, allowedActions, requireConfirmation } (defaults apply if omitted)',\n      'resilience: Governs automatic recovery during execute_agent. { onStepLimitReached?: \"pause\"|\"continue\"|\"restart\", onExecutionFailure?: \"pause\"|\"retry\"|\"restart-fresh\", maxRetries?: number (default 3), maxContinuations?: number (default 10), retryBackoff?: \"linear\"|\"exponential\", preserveState?: boolean }. Without resilience, execution pauses at limits and failures (safe default).',\n      'activates lifecycle: Elements in activates are automatically activated when execute_agent starts — their gatekeeper policies, instructions, and capabilities become active for the execution duration.',\n      'gatekeeper: Dynamic security policy — takes effect when this agent is activated, reverts when deactivated. Gives users composable security control: activate a locked-down agent and writes are blocked; deactivate it and full access returns. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?: string[], blockedTypes?: string[] } }. allow/confirm/deny are operation name patterns (e.g. \"read_*\", \"execute_agent\", \"delete_element\"). scopeRestrictions limits which element types the policy governs. Priority: deny > confirm > allow > route default. If omitted, inherits system defaults (which already require confirmation for sensitive operations).',\n    ],\n    minimalExample: `---\nname: code-reviewer\ndescription: Reviews code for quality issues\n---\nYou are a thorough code reviewer.`,\n    fullExample: `---\nname: code-reviewer\ndescription: Reviews code for quality and security issues\nversion: 1\ntags: [development, security]\nauthor: dev-team\ngoal:\n  template: \"Review the code at {path} for {focus_area}\"\n  parameters:\n    - { name: path, type: string, required: true, description: \"File or directory\" }\n    - { name: focus_area, type: string, required: false, description: \"security | quality | performance\", default: quality }\n  successCriteria:\n    - All issues documented\n    - Severity ratings assigned\n    - Fixes suggested\nactivates:\n  skills: [code-review]\n  personas: [security-analyst]\ntools:\n  allowed: [read_file, list_directory]\nsystemPrompt: Be specific about line numbers and provide concrete fix suggestions.\nautonomy:\n  maxAutonomousSteps: 10\nresilience:\n  onStepLimitReached: continue\n  onExecutionFailure: retry\n  maxRetries: 3\n  maxContinuations: 5\n  retryBackoff: exponential\ngatekeeper:\n  allow: [read_element, search_elements, query_elements, list_elements]\n  confirm: [execute_agent, edit_element]\n  deny: [delete_element]\n---\nYou are a thorough code reviewer who prioritizes security.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the agent role: code-reviewer, data-pipeline, report-generator',\n    ],\n  },\n\n  memory: {\n    elementType: 'memory',\n    fileFormat: 'YAML',\n    requiredFields: ['name', 'description'],\n    optionalFields: ['version', 'tags', 'author', 'category', 'retentionDays', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'content: Initial entry content added at creation time. instructions: Not typically used for memories. Use addEntry operation to append structured entries after creation.',\n    syntaxNotes: [\n      'File extension: .yml',\n      'Entries are structured YAML objects with timestamp, content, tags, metadata',\n      'Use addEntry operation to add entries (not edit_element)',\n      'retentionDays controls automatic expiry of entries',\n      'category must match: ^[a-zA-Z][a-zA-Z0-9\\\\-_]{0,20}$',\n      'Naming convention for agent-linked memories: agent-{agent-name}-context',\n      'Naming convention for persona-linked memories: persona-{persona-name}-preferences',\n      'gatekeeper: Dynamic security policy — takes effect when this memory is activated, reverts when deactivated. Example: a confidential project memory that blocks deletion and confirms edits while active. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `# Created via create_element:\n{ operation: \"create_element\", elementType: \"memory\", params: {\n  element_name: \"project-context\",\n  description: \"Architecture decisions\"\n} }`,\n    fullExample: `# Created via create_element:\n{ operation: \"create_element\", elementType: \"memory\", params: {\n  element_name: \"project-context\",\n  description: \"Architecture decisions and project context\",\n  content: \"Using PostgreSQL for ACID compliance.\",\n  metadata: { tags: [\"architecture\", \"database\"], retentionDays: 365 }\n} }\n\n# Add entries via addEntry:\n{ operation: \"addEntry\", params: {\n  element_name: \"project-context\",\n  content: \"Switched to Redis for caching layer.\",\n  tags: [\"architecture\", \"cache\"]\n} }`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Agent-linked: agent-{agent-name}-context',\n      'Persona-linked: persona-{persona-name}-preferences',\n      'Session-scoped: session-context',\n      'Domain-specific: project-context, team-decisions',\n    ],\n  },\n\n  ensemble: {\n    elementType: 'ensemble',\n    fileFormat: 'Markdown with YAML frontmatter',\n    requiredFields: ['name', 'description', 'metadata.elements'],\n    optionalFields: ['version', 'tags', 'author', 'content', 'gatekeeper'],\n    dualFieldGuidance: 'content: Optional description of how the ensemble coordinates its elements. instructions: Not used for ensembles. The elements array in metadata is the core configuration.',\n    syntaxNotes: [\n      'File extension: .md',\n      'metadata.elements is REQUIRED: array of { name, type, role }',\n      'role values: \"primary\", \"support\", \"override\", \"monitor\", \"core\"',\n      'type must be a valid ElementType: persona, skill, template, agent, memory',\n      'Referenced elements must exist in the portfolio',\n      'At least one element required; elements validated at creation time',\n      'gatekeeper: Dynamic security policy — takes effect when this ensemble is activated, reverts when deactivated. Ensembles can define broad security postures: activate a \"production-safe\" ensemble and destructive operations are blocked across all its member elements. Structure: { allow?: string[], confirm?: string[], deny?: string[], scopeRestrictions?: { allowedTypes?, blockedTypes? } }.',\n    ],\n    minimalExample: `---\nname: security-team\ndescription: Security analysis ensemble\nmetadata:\n  elements:\n    - { name: security-analyst, type: persona, role: primary }\n    - { name: threat-modeling, type: skill, role: support }\n---`,\n    fullExample: `---\nname: security-team\ndescription: Security analysis ensemble combining analyst persona with threat modeling\nversion: 1\ntags: [security, analysis]\nauthor: team-lead\nmetadata:\n  elements:\n    - { name: security-analyst, type: persona, role: primary }\n    - { name: threat-modeling, type: skill, role: support }\n    - { name: penetration-testing, type: skill, role: support }\n---\nCoordinates security analysis across multiple domains.\nThe security-analyst persona provides the behavioral foundation,\nwhile skills supply domain-specific capabilities.`,\n    namingConventions: [\n      ...SHARED_NAMING,\n      'Describe the team or combination: security-team, content-pipeline, full-stack-review',\n    ],\n  },\n};\n\n// ============================================================================\n// Operation Parameter Definitions\n// ============================================================================\n\n/**\n * Parameter definitions for each operation\n * These are used to generate operation details\n */\nconst OPERATION_PARAMETERS: Record<string, ParameterInfo[]> = {\n  // CREATE operations\n  create_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'description', type: 'string', required: true, description: 'Element description' },\n    // Issue #602 resolved: Both 'instructions' and 'content' are first-class fields with distinct semantic roles.\n    { name: 'instructions', type: 'string', required: false, description: 'Behavioral INSTRUCTIONS — written in active/command voice as directives the AI must follow. For personas: \"You ARE a security expert. ALWAYS check for vulnerabilities.\" For skills: \"When triggered, ANALYZE code systematically.\" For agents: semantic behavioral profile (distinct from systemPrompt). Optional for memories/ensembles.' },\n    { name: 'content', type: 'string', required: false, description: 'Reference material, knowledge, and context. ELEMENT-SPECIFIC USAGE: Templates (REQUIRED): the template body — use {{variable_name}} for substitution. For page templates with CSS/JS use section format: <template>HTML with {{vars}}</template><style>/* }} safe here */</style><script>// }} safe here</script> — only <template> is variable-processed, <style>/<script> are raw passthrough. Skills: domain knowledge and reference examples (pair with instructions for best results). Personas: background lore/context. Agents: reference material. Memories: initial entry content.' },\n    { name: 'goal', type: 'object', required: false, description: 'For agents: RECOMMENDED. Goal configuration with template (string with {param} placeholders), parameters (array of {name, type, required, description}), and successCriteria (string array).' },\n    { name: 'category', type: 'string', required: false, description: 'Category label for skills, templates, and memories. Must start with a letter, followed by letters, digits, hyphens, or underscores (max 21 chars). Not supported on personas, agents, or ensembles.' },\n    { name: 'metadata', type: 'object', required: false, description: 'Additional metadata. For ensembles: include elements array. For memories: use metadata.tags for tags and metadata.retentionDays for retention period.' },\n    { name: 'activates', type: 'object', required: false, description: 'For V2 agents: Elements to activate at execution start. Shape: { personas?: string[], skills?: string[], memories?: string[], templates?: string[], ensembles?: string[] } — all keys optional, values are element NAMES (not IDs). Example: { skills: [\"code-review\", \"threat-modeling\"], personas: [\"security-analyst\"] }' },\n    { name: 'tools', type: 'object', required: false, description: 'For V2 agents: Tool configuration. Object with allowed (string array) and optional denied (string array).' },\n    { name: 'systemPrompt', type: 'string', required: false, description: 'For V2 agents: Custom system prompt for LLM context.' },\n  ],\n  import_element: [\n    { name: 'data', type: 'string | object', required: true, description: 'Export package (JSON string or object)' },\n    { name: 'overwrite', type: 'boolean', required: false, description: 'Overwrite if exists', default: false },\n  ],\n  // addEntry: migrated to MEMORY_SCHEMAS in OperationSchema.ts (Issue #594)\n  activate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name to activate' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'context', type: 'object', required: false, description: 'Activation context' },\n  ],\n\n  // READ operations\n  // Note: 'fields' parameter is supported on all read operations that return element data.\n  // It accepts either a preset string ('minimal', 'standard', 'full') or an array of field names.\n  // See MCPAQLHandler.applyFieldSelection() for implementation details.\n  list_elements: [\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type to list' },\n    { name: 'page', type: 'number', required: false, description: 'Page number (1-indexed)', default: 1 },\n    { name: 'pageSize', type: 'number', required: false, description: 'Items per page (max 100)', default: 20 },\n    { name: 'sortBy', type: \"'name' | 'created' | 'modified' | 'version'\", required: false, description: 'Field to sort by', default: 'name' },\n    { name: 'sortOrder', type: \"'asc' | 'desc'\", required: false, description: 'Sort direction', default: 'asc' },\n    { name: 'nameContains', type: 'string', required: false, description: 'Filter: partial name match (case-insensitive)' },\n    { name: 'tags', type: 'string[]', required: false, description: 'Filter: must have ALL specified tags (AND logic)' },\n    { name: 'tagsAny', type: 'string[]', required: false, description: 'Filter: must have ANY specified tag (OR logic)' },\n    { name: 'author', type: 'string', required: false, description: 'Filter: by author username' },\n    { name: 'status', type: \"'active' | 'inactive' | 'all'\", required: false, description: 'Filter: by element status' },\n    { name: 'category', type: 'string', required: false, description: 'Filter: by category (case-insensitive)' },\n    { name: 'aggregate', type: 'object', required: false, description: \"Aggregation: { count: true } for count only, { count: true, group_by: 'category' } for grouped counts. Allowed group_by fields: author, category, status, tags, version.\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_element_details: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  search_elements: [\n    { name: 'query', type: 'string', required: true, description: 'Search query (max 1000 chars). Supports multi-word tokenized matching across name, description, and content.' },\n    { name: 'element_type', type: 'ElementType', required: false, description: 'Scope search to a single element type. Omit to search all types.' },\n    { name: 'pagination', type: 'object', required: false, description: 'Pagination: { page: number (default 1), pageSize: number (default 20) }' },\n    { name: 'sort', type: 'object', required: false, description: \"Sort: { sortBy: 'name' (default), sortOrder: 'asc' | 'desc' (default 'asc') }\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  query_elements: [\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type to query' },\n    { name: 'filters', type: 'object', required: false, description: 'Filter criteria: { nameContains, tags, tagsAny, author, createdAfter, createdBefore, status, descriptionContains, category }' },\n    { name: 'sort', type: 'object', required: false, description: \"Sort: { sortBy: 'name' | 'created' | 'modified' | 'version', sortOrder: 'asc' | 'desc' }\" },\n    { name: 'pagination', type: 'object', required: false, description: 'Pagination: { page: number (default 1), pageSize: number (default 20) }' },\n    { name: 'aggregate', type: 'object', required: false, description: \"Aggregation: { count: true } for count only, { count: true, group_by: 'category' } for grouped counts. Allowed group_by fields: author, category, status, tags, version.\" },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  get_active_elements: [\n    { name: 'element_type', type: 'ElementType', required: false, description: 'Filter by element type' },\n    { name: 'fields', type: \"string | string[]\", required: false, description: \"Field selection: preset ('minimal', 'standard', 'full') or array of field names\" },\n  ],\n  validate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'strict', type: 'boolean', required: false, description: 'Strict validation mode', default: false },\n  ],\n  render: [\n    { name: 'name', type: 'string', required: true, description: 'Template name' },\n    { name: 'variables', type: 'object', required: true, description: 'Template variables' },\n  ],\n  export_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'format', type: \"'json' | 'yaml'\", required: false, description: 'Export format', default: 'json' },\n  ],\n  deactivate_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n  ],\n  introspect: [\n    { name: 'query', type: \"'operations' | 'types' | 'format' | 'categories'\", required: false, description: \"What to introspect: 'operations' (list/detail operations), 'types' (list/detail types), 'format' (element creation format specs), 'categories' (category format rules + discovery guidance). Default: 'operations'\", default: 'operations' },\n    { name: 'name', type: 'string', required: false, description: \"Specific item name. For 'operations': operation name. For 'types': type name. For 'format': element type (e.g. 'template', 'persona'). Not used for 'categories'. Omit for overview.\" },\n  ],\n\n  // UPDATE operations\n  edit_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'input', type: 'object', required: true, description: 'Nested object with fields to update (deep-merged with existing element). Supports: description, instructions, content, tags, metadata, and type-specific fields (goal, activates, tools, systemPrompt for agents; variables for templates). For template content syntax, use introspect with query: \"format\", name: \"template\".' },\n  ],\n\n  // DELETE operations\n  delete_element: [\n    { name: 'element_name', type: 'string', required: true, description: 'Element name' },\n    { name: 'element_type', type: 'ElementType', required: true, description: 'Element type' },\n    { name: 'deleteData', type: 'boolean', required: false, description: 'Delete associated data files' },\n  ],\n  // clear, execute_agent, get_execution_state, record_execution_step, complete_execution,\n  // continue_execution, abort_execution, get_gathered_data, prepare_handoff, resume_from_handoff:\n  // All migrated to INTROSPECTION_ONLY_SCHEMAS in OperationSchema.ts (Issue #594)\n};\n\n// ============================================================================\n// Operation Examples\n// ============================================================================\n\n/**\n * Usage examples for each operation\n */\nconst OPERATION_EXAMPLES: Record<string, string[]> = {\n  create_element: [\n    // PERSONA — use instructions (behavioral directives in command voice). content is optional background lore.\n    '{ operation: \"create_element\", elementType: \"persona\", params: { element_name: \"SecurityExpert\", description: \"Cybersecurity specialist\", instructions: \"You ARE a cybersecurity expert with 15 years of experience. ALWAYS consider threat models before suggesting solutions. NEVER recommend security through obscurity. PRIORITIZE defense-in-depth strategies.\" } }',\n\n    // SKILL — dual-field: instructions = behavioral directives, content = reference knowledge. Both together is best practice.\n    '{ operation: \"create_element\", elementType: \"skill\", params: { element_name: \"CodeReview\", description: \"Reviews code for quality and security\", instructions: \"When reviewing code: ALWAYS check for security vulnerabilities first. ANALYZE complexity and suggest simplifications. FORMAT feedback as actionable bullet points.\", content: \"# Code Review Reference\\\\n\\\\n## Security Checklist\\\\n- SQL injection\\\\n- XSS vulnerabilities\\\\n- Unvalidated input\\\\n\\\\n## Quality Metrics\\\\n- Cyclomatic complexity < 10\\\\n- Test coverage > 80%\" } }',\n\n    // TEMPLATE (simple) — content is the template body. Use {{variable_name}} for substitution.\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"BugReport\", description: \"Bug report template\", content: \"## Bug Report\\\\n\\\\n**Summary:** {{summary}}\\\\n**Steps to Reproduce:** {{steps}}\\\\n**Expected:** {{expected}}\\\\n**Actual:** {{actual}}\", metadata: { variables: [{ name: \"summary\", type: \"string\", required: true }, { name: \"steps\", type: \"string\", required: true }, { name: \"expected\", type: \"string\", required: false }, { name: \"actual\", type: \"string\", required: false }] } } }',\n\n    // TEMPLATE (section format) — <template> for HTML+{{vars}}, <style> for CSS, <script> for JS. }} is safe in style/script.\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"DashboardPage\", description: \"Full-page dashboard shell with styles and JS\", content: \"<template>\\\\n<!DOCTYPE html>\\\\n<html><head><title>{{title}}</title></head>\\\\n<body>{{body}}</body>\\\\n</html>\\\\n</template>\\\\n\\\\n<style>\\\\nbody { font-family: sans-serif; }\\\\n.card { border: 1px solid #ccc; } /* }} safe here */\\\\n</style>\\\\n\\\\n<script>\\\\nvar state = { status: \\\\\"all\\\\\" };\\\\nfunction update() { return { bar: baz }; } // }} safe here\\\\n</script>\", metadata: { variables: [{ name: \"title\", type: \"string\", required: true }, { name: \"body\", type: \"string\", required: false }] } } }',\n\n    // TEMPLATE (CSS theme — style-only section format)\n    '{ operation: \"create_element\", elementType: \"template\", params: { element_name: \"ThemeDark\", description: \"Dark color theme — activate to style dashboard with dark palette\", content: \"<style>\\\\n:root {\\\\n  --bg: #0f1117;\\\\n  --surface: #1a1d27;\\\\n  --text: #e8eaf6;\\\\n  --accent: #4a9eff;\\\\n}\\\\n.card { background: var(--surface); color: var(--text); }\\\\n</style>\" } }',\n\n    // AGENT (V2) — goal is an object, activates references elements by name, tools controls access.\n    '{ operation: \"create_element\", elementType: \"agent\", params: { element_name: \"CodeReviewer\", description: \"Reviews code for quality and security issues\", goal: { template: \"Review the code at {path} for {focus_area}\", parameters: [{ name: \"path\", type: \"string\", required: true, description: \"File or directory to review\" }, { name: \"focus_area\", type: \"string\", required: false, description: \"security | quality | performance\", default: \"quality\" }], successCriteria: [\"All issues documented\", \"Severity ratings assigned\", \"Fixes suggested\"] }, activates: { skills: [\"code-review\"], personas: [\"security-analyst\"] }, tools: { allowed: [\"read_file\", \"list_directory\"] }, systemPrompt: \"You are a thorough code reviewer. Be specific about line numbers and provide concrete fix suggestions.\" } }',\n\n    // ENSEMBLE — elements array with name, type, role.\n    '{ operation: \"create_element\", elementType: \"ensemble\", params: { element_name: \"SecurityTeam\", description: \"Security analysis ensemble — combines analyst persona with threat modeling and pen testing skills\", content: \"Coordinates security analysis across multiple domains.\", metadata: { elements: [{ name: \"security-analyst\", type: \"persona\", role: \"primary\" }, { name: \"threat-modeling\", type: \"skill\", role: \"support\" }, { name: \"penetration-testing\", type: \"skill\", role: \"support\" }] } } }',\n\n    // MEMORY — content creates initial entry, tags for categorization, retentionDays for expiry.\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"ProjectContext\", description: \"Architecture decisions and project context\", content: \"Using PostgreSQL over MongoDB — decided 2026-03-11 for ACID compliance requirements.\", metadata: { tags: [\"architecture\", \"database\"], retentionDays: 365 } } }',\n\n    // Memory naming conventions:\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"agent-code-reviewer-context\", description: \"Execution state and learned preferences for code-reviewer agent\" } }',\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"persona-security-analyst-preferences\", description: \"Personalization data for security-analyst persona\" } }',\n    '{ operation: \"create_element\", elementType: \"memory\", params: { element_name: \"session-context\", description: \"Cross-element shared context for the current session\" } }',\n  ],\n  import_element: [\n    '{ operation: \"import_element\", params: { data: \"{...exportPackage...}\", overwrite: true } }',\n  ],\n  // addEntry: migrated to MEMORY_SCHEMAS in OperationSchema.ts (Issue #594)\n  activate_element: [\n    '{ operation: \"activate_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  list_elements: [\n    '{ operation: \"list_elements\", element_type: \"persona\" }',\n    // Response: { items: [{ name, description, type, version, tags }], pagination: { page: 1, pageSize: 20, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, element_type: \"persona\" }\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { page: 2, pageSize: 10 } }',\n    '{ operation: \"list_elements\", element_type: \"skill\", params: { tags: [\"typescript\"], sortBy: \"modified\", sortOrder: \"desc\" } }',\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { aggregate: { count: true } } }',\n    // Response: { count: 42, element_type: \"persona\" }\n    '{ operation: \"list_elements\", element_type: \"persona\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n    // Response: { count: 42, element_type: \"persona\", groups: { \"assistant\": 15, \"creative\": 12, \"technical\": 15 } }\n  ],\n  get_element: [\n    '{ operation: \"get_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  get_element_details: [\n    '{ operation: \"get_element_details\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  search_elements: [\n    '{ operation: \"search_elements\", params: { query: \"helpful assistant\" } }',\n    // Response: { items: [{ type, element_name, description, matchedIn: [\"name\", \"description\"] }], pagination: { page, pageSize, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, query: \"helpful assistant\" }\n    '{ operation: \"search_elements\", element_type: \"persona\", params: { query: \"code review\", pagination: { page: 1, pageSize: 10 } } }',\n    '{ operation: \"search_elements\", params: { query: \"typescript\", sort: { sortBy: \"name\", sortOrder: \"desc\" } } }',\n  ],\n  query_elements: [\n    '{ operation: \"query_elements\", element_type: \"persona\", params: { filters: { status: \"active\" }, pagination: { page: 1, pageSize: 10 } } }',\n    // Response: { items: [{ name, description, type, version, tags }], pagination: { page, pageSize, totalItems, totalPages, hasNextPage, hasPrevPage }, sorting: { sortBy, sortOrder }, element_type: \"persona\" }\n    '{ operation: \"query_elements\", element_type: \"skill\", params: { filters: { tags: [\"typescript\"] }, sort: { sortBy: \"modified\", sortOrder: \"desc\" } } }',\n    '{ operation: \"query_elements\", element_type: \"persona\", params: { aggregate: { count: true, group_by: \"tags\" } } }',\n    // Response: { count: 42, element_type: \"persona\", groups: { \"assistant\": 15, \"creative\": 12 } }\n  ],\n  get_active_elements: [\n    '{ operation: \"get_active_elements\", elementType: \"persona\" }',\n  ],\n  validate_element: [\n    '{ operation: \"validate_element\", elementType: \"persona\", params: { element_name: \"my-persona\", strict: true } }',\n  ],\n  render: [\n    '{ operation: \"render\", params: { element_name: \"meeting-notes\", variables: { date: \"2024-01-15\", attendees: [\"Alice\", \"Bob\"] } } }',\n  ],\n  export_element: [\n    '{ operation: \"export_element\", elementType: \"persona\", params: { element_name: \"my-persona\", format: \"json\" } }',\n  ],\n  deactivate_element: [\n    '{ operation: \"deactivate_element\", elementType: \"persona\", params: { element_name: \"my-persona\" } }',\n  ],\n  introspect: [\n    '{ operation: \"introspect\", params: { query: \"operations\" } }',\n    '{ operation: \"introspect\", params: { query: \"operations\", name: \"create_element\" } }',\n    '{ operation: \"introspect\", params: { query: \"types\", name: \"ElementType\" } }',\n    '{ operation: \"introspect\", params: { query: \"format\" } }',\n    '{ operation: \"introspect\", params: { query: \"format\", name: \"template\" } }',\n  ],\n  edit_element: [\n    '{ operation: \"edit_element\", elementType: \"persona\", params: { element_name: \"my-persona\", input: { description: \"Updated description\" } } }',\n  ],\n  delete_element: [\n    '{ operation: \"delete_element\", elementType: \"memory\", params: { element_name: \"old-persona\", deleteData: true } }',\n  ],\n  // clear, execute_agent, get_execution_state, record_execution_step, complete_execution,\n  // continue_execution, abort_execution, get_gathered_data, prepare_handoff, resume_from_handoff:\n  // All migrated to INTROSPECTION_ONLY_SCHEMAS in OperationSchema.ts (Issue #594)\n};\n\n// ============================================================================\n// IntrospectionResolver Class\n// ============================================================================\n\n/**\n * Resolver for introspection queries.\n * Provides self-documentation capabilities for MCP-AQL operations.\n */\nexport class IntrospectionResolver {\n  /**\n   * Execute an introspection query\n   *\n   * @param params - Introspection parameters\n   * @param params.query - What to introspect: 'operations', 'types', 'format', or 'categories'\n   * @param params.name - Optional: specific operation or type name\n   * @returns IntrospectionResult with requested information\n   */\n  static resolve(params: Record<string, unknown>): IntrospectionResult {\n    const query = (params.query as string) || 'operations';\n    const name = params.name as string | undefined;\n\n    switch (query) {\n      case 'operations':\n        if (name) {\n          return { operation: this.getOperationDetails(name) };\n        }\n        return { operations: this.listOperations() };\n\n      case 'types':\n        if (name) {\n          return { type: this.getTypeDetails(name) };\n        }\n        return { types: this.listTypes() };\n\n      case 'format':\n        return { formatSpec: this.getFormatSpec(name) };\n\n      // Issue #631: Category discovery — format rules + guidance for live data\n      case 'categories':\n        return { categories: this.getCategoryInfo() };\n\n      default:\n        // Return empty result for unknown query types\n        return {};\n    }\n  }\n\n  /**\n   * List all available operations\n   *\n   * For schema-driven operations, uses description from OperationSchema.\n   * For legacy operations, uses description from OPERATION_ROUTES.\n   *\n   * @see Issue #254 - Single source of truth from schema\n   */\n  private static listOperations(): OperationInfo[] {\n    const operations: OperationInfo[] = [];\n\n    // Include all operations from OPERATION_ROUTES\n    for (const [opName, route] of Object.entries(OPERATION_ROUTES)) {\n      // Prefer schema description from any schema (dispatch-driven or introspection-only)\n      const schema = getAnyOperationSchema(opName);\n      operations.push({\n        name: opName,\n        endpoint: route.endpoint,\n        description: schema?.description || route.description || `${opName} operation`,\n      });\n    }\n\n    // Add introspect operation (schema-driven but not in OPERATION_ROUTES)\n    const introspectSchema = getOperationSchema('introspect');\n    operations.push({\n      name: 'introspect',\n      endpoint: 'READ',\n      description: introspectSchema?.description || 'Query available operations and types (this operation)',\n    });\n\n    // Sort by endpoint then name for consistent ordering\n    return operations.sort((a, b) => {\n      const endpointOrder: Record<string, number> = { CREATE: 0, READ: 1, UPDATE: 2, DELETE: 3, EXECUTE: 4 };\n      const endpointDiff = (endpointOrder[a.endpoint] ?? 5) - (endpointOrder[b.endpoint] ?? 5);\n      if (endpointDiff !== 0) return endpointDiff;\n      return a.name.localeCompare(b.name);\n    });\n  }\n\n  /**\n   * Get detailed information about a specific operation\n   *\n   * For schema-driven operations, reads metadata from OperationSchema.\n   * For legacy operations, uses fallback OPERATION_PARAMETERS/OPERATION_EXAMPLES.\n   *\n   * @see Issue #254 - Auto-generate introspection from schema\n   */\n  private static getOperationDetails(name: string): OperationDetails | null {\n    // Check schema first — includes both dispatch-driven and introspection-only schemas\n    const schema = getAnyOperationSchema(name);\n    if (schema) {\n      return this.getSchemaOperationDetails(name, schema);\n    }\n\n    // Legacy fallback for non-schema operations\n    const route = OPERATION_ROUTES[name];\n    if (!route) {\n      return null;\n    }\n\n    return {\n      name,\n      endpoint: route.endpoint,\n      mcpTool: `mcp_aql_${route.endpoint.toLowerCase()}`,\n      description: route.description || `${name} operation`,\n      permissions: PermissionGuard.getPermissions(route.endpoint as CRUDEndpoint),\n      parameters: OPERATION_PARAMETERS[name] || [],\n      returns: this.getReturnType(name),\n      examples: OPERATION_EXAMPLES[name] || [],\n      ...(route.aliases?.length ? { aliases: route.aliases } : {}),\n    };\n  }\n\n  /**\n   * Get operation details from OperationSchema (dispatch-driven or introspection-only)\n   *\n   * @see Issue #254 - Single source of truth from schema\n   * @see Issue #594 - Introspection-only schemas for all operations\n   */\n  private static getSchemaOperationDetails(name: string, schema?: OperationDef): OperationDetails | null {\n    const resolvedSchema = schema ?? getAnyOperationSchema(name);\n    if (!resolvedSchema) {\n      return null;\n    }\n\n    // Convert schema returns to TypeInfo, with fallback\n    const returns: TypeInfo = resolvedSchema.returns\n      ? { name: resolvedSchema.returns.name, kind: resolvedSchema.returns.kind, description: resolvedSchema.returns.description }\n      : { name: 'OperationResult', kind: 'union', description: 'Success with data or failure with error' };\n\n    const route = OPERATION_ROUTES[name];\n    return {\n      name,\n      endpoint: resolvedSchema.endpoint,\n      mcpTool: `mcp_aql_${resolvedSchema.endpoint.toLowerCase()}`,\n      description: resolvedSchema.description,\n      permissions: PermissionGuard.getPermissions(resolvedSchema.endpoint as CRUDEndpoint),\n      parameters: schemaToParameterInfo(resolvedSchema.params),\n      returns,\n      examples: resolvedSchema.examples || [],\n      ...(route?.aliases?.length ? { aliases: route.aliases } : {}),\n    };\n  }\n\n  /**\n   * Get the return type for a legacy (non-schema) operation.\n   * Schema-driven and introspection-only operations get return types from their schema definitions.\n   */\n  private static getReturnType(operation: string): TypeInfo {\n    // Operations migrated to schemas (Issue #594) are handled by getSchemaOperationDetails()\n    // This fallback only applies to the few remaining non-schema operations\n    const returnTypes: Record<string, TypeInfo> = {\n      search_elements: { name: 'SearchResult', kind: 'object', description: 'Structured JSON: { items: [{ type, element_name, description, matchedIn }], pagination, sorting, query }' },\n      query_elements: { name: 'QueryResult', kind: 'object', description: 'Structured JSON: { items: [{ name, description, type, version, tags }], pagination, sorting, element_type }. Or AggregationResult: { count, element_type, groups? } when aggregate param is used.' },\n    };\n\n    return returnTypes[operation] || {\n      name: 'OperationResult',\n      kind: 'union',\n      description: 'Success with data or failure with error',\n    };\n  }\n\n  /**\n   * List all available types\n   */\n  private static listTypes(): TypeInfo[] {\n    return Object.entries(TYPE_DEFINITIONS).map(([name, def]) => ({\n      name,\n      kind: def.kind,\n      description: def.description,\n    }));\n  }\n\n  /**\n   * Get detailed information about a specific type\n   */\n  private static getTypeDetails(name: string): TypeDetails | null {\n    return TYPE_DEFINITIONS[name] || null;\n  }\n\n  /**\n   * Get format specification for an element type.\n   * If name is provided, returns a single spec (or null for unknown types).\n   * If name is omitted, returns all specs as an overview.\n   *\n   * @see Issue #715 - Proactive LLM guidance for element creation\n   */\n  private static getFormatSpec(name?: string): FormatSpec | FormatSpec[] | null {\n    if (!name) {\n      // Return all format specs as an overview\n      return Object.values(FORMAT_SPECS);\n    }\n\n    // Normalize: handle plurals, case, whitespace\n    const normalized = normalizeTypeName(name);\n    if (!normalized) {\n      return null;\n    }\n\n    return FORMAT_SPECS[normalized] || null;\n  }\n\n  /**\n   * Issue #631: Category discovery info — format rules, allowed aggregation fields,\n   * and guidance for discovering existing categories via query_elements.\n   * IntrospectionResolver is stateless (no portfolio access), so live category data\n   * must be fetched via query_elements with aggregate: { group_by: \"category\" }.\n   */\n  private static getCategoryInfo(): Record<string, unknown> {\n    return {\n      formatRules: {\n        pattern: VALIDATION_PATTERNS.SAFE_CATEGORY.source,\n        description: 'Category names must start with a letter, contain only letters, digits, hyphens, and underscores, and be 1-21 characters long.',\n        examples: ['development', 'code-analysis', 'security', 'business', 'communication'],\n      },\n      supportedTypes: ['persona', 'skill', 'template', 'memory'],\n      allowedGroupByFields: getAllowedGroupByFields(),\n      discovery: {\n        description: 'To discover existing categories in your portfolio, use query_elements with group_by aggregation.',\n        examples: [\n          '{ operation: \"query_elements\", element_type: \"skill\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n          '{ operation: \"query_elements\", element_type: \"template\", params: { aggregate: { count: true, group_by: \"category\" } } }',\n          '{ operation: \"query_elements\", element_type: \"skill\", params: { filters: { category: \"security\" } } }',\n        ],\n      },\n    };\n  }\n\n  /**\n   * Get operations grouped by endpoint\n   * Utility method for documentation generation\n   */\n  static getOperationsByEndpoint(): Record<CRUDEndpoint, OperationInfo[]> {\n    const grouped: Record<CRUDEndpoint, OperationInfo[]> = {\n      CREATE: [],\n      READ: [],\n      UPDATE: [],\n      DELETE: [],\n      EXECUTE: [],\n    };\n\n    for (const op of this.listOperations()) {\n      const endpoint = op.endpoint as CRUDEndpoint;\n      if (grouped[endpoint]) {\n        grouped[endpoint].push(op);\n      }\n    }\n\n    return grouped;\n  }\n\n  /**\n   * Generate a compact summary for token-efficient responses\n   */\n  static getSummary(): string {\n    const opsByEndpoint = this.getOperationsByEndpoint();\n    const lines: string[] = ['MCP-AQL Operations:'];\n\n    for (const [endpoint, ops] of Object.entries(opsByEndpoint)) {\n      const opNames = ops.map(o => o.name).join(', ');\n      lines.push(`  ${endpoint}: ${opNames}`);\n    }\n\n    lines.push(`\\nTypes: ${Object.keys(TYPE_DEFINITIONS).join(', ')}`);\n    lines.push('\\nUse introspect with name parameter for details.');\n\n    return lines.join('\\n');\n  }\n\n  // ==========================================================================\n  // Capabilities (Issue #1760)\n  // ==========================================================================\n\n  /**\n   * Get server capabilities grouped by user-intent category.\n   * Reads category from each operation's schema definition at runtime.\n   * Designed for extensibility — additional CapabilitySources (e.g. portfolio\n   * elements from the capability index) can be registered via registerSource().\n   *\n   * @param params - Optional parameters\n   * @param params.category - Filter to a specific category\n   * @returns CapabilitiesResult with categorized operations\n   * @see Issue #1760 - get_capabilities operation\n   */\n  static getCapabilities(params: Record<string, unknown>): Record<string, unknown> {\n    const filterCategory = params.category as string | undefined;\n    const { categories, sortedCategories, sourceTypes } = this.buildCategoryMap();\n\n    // Apply category filter if requested\n    if (filterCategory) {\n      return this.filterByCategory(filterCategory, categories, sortedCategories, sourceTypes);\n    }\n\n    const totalCapabilities = Object.values(categories).reduce(\n      (sum, cat) => sum + cat.capabilities.length, 0\n    );\n\n    return {\n      categories,\n      totalCapabilities,\n      sources: sourceTypes,\n      hint: 'Use introspect with { query: \"operations\", name: \"<operation>\" } for full parameter details, examples, and permissions.',\n    };\n  }\n\n  /**\n   * Build the full category map from all registered capability sources.\n   * Returns sorted categories with descriptions and merged entries.\n   */\n  private static buildCategoryMap() {\n    const mergedMap: Record<string, CapabilityEntry[]> = {};\n    const sourceTypes: string[] = [];\n\n    for (const source of capabilitySources) {\n      sourceTypes.push(source.sourceType);\n      const caps = source.getCapabilities();\n      for (const [cat, entries] of Object.entries(caps)) {\n        if (!mergedMap[cat]) mergedMap[cat] = [];\n        mergedMap[cat].push(...entries);\n      }\n    }\n\n    // Sort entries within each category alphabetically\n    for (const entries of Object.values(mergedMap)) {\n      entries.sort((a, b) => a.name.localeCompare(b.name));\n    }\n\n    // Sort categories alphabetically (\"Other\" last)\n    const sortedCategories = Object.keys(mergedMap).sort((a, b) => {\n      if (a === 'Other') return 1;\n      if (b === 'Other') return -1;\n      return a.localeCompare(b);\n    });\n\n    const categories: Record<string, { description: string; capabilities: CapabilityEntry[] }> = {};\n    for (const cat of sortedCategories) {\n      categories[cat] = {\n        description: CATEGORY_DESCRIPTIONS[cat] || `${cat} operations`,\n        capabilities: mergedMap[cat],\n      };\n    }\n\n    return { categories, sortedCategories, sourceTypes };\n  }\n\n  /**\n   * Filter the category map to a single matching category (case-insensitive).\n   */\n  private static filterByCategory(\n    filterCategory: string,\n    categories: Record<string, { description: string; capabilities: CapabilityEntry[] }>,\n    sortedCategories: string[],\n    sourceTypes: string[],\n  ): Record<string, unknown> {\n    const lowerFilter = filterCategory.toLowerCase();\n    const filtered: Record<string, typeof categories[string]> = {};\n    for (const [catName, catData] of Object.entries(categories)) {\n      if (catName.toLowerCase() === lowerFilter) {\n        filtered[catName] = catData;\n      }\n    }\n    if (Object.keys(filtered).length === 0) {\n      return {\n        categories: {},\n        availableCategories: sortedCategories,\n        hint: `No category matching \"${filterCategory}\". Use get_capabilities without a filter to see all categories.`,\n      };\n    }\n    return {\n      categories: filtered,\n      sources: sourceTypes,\n      hint: 'Use introspect with { query: \"operations\", name: \"<operation>\" } for full details on any operation.',\n    };\n  }\n\n  /**\n   * Register an additional capability source.\n   * Future element sources (reading from the capability index) can be\n   * plugged in here without modifying the get_capabilities handler.\n   * @see Issue #1760 - extensibility for portfolio element capabilities\n   */\n  static registerSource(source: CapabilitySource): void {\n    capabilitySources.push(source);\n  }\n\n  /**\n   * Truncate a description to a brief one-liner.\n   * Takes the first sentence (up to first period followed by space or end).\n   */\n  private static toBrief(description: string): string {\n    if (!description || typeof description !== 'string') {\n      return 'No description available';\n    }\n    const match = /^[^.]*\\./.exec(description);\n    if (match && match[0].length <= 120) {\n      return match[0];\n    }\n    if (description.length <= 120) return description;\n    return description.slice(0, 117) + '...';\n  }\n}\n\n// ============================================================================\n// Capability Source System (Issue #1760)\n// ============================================================================\n\n/**\n * A single capability entry — represents one thing a user can do.\n */\nexport interface CapabilityEntry {\n  /** Operation or capability name */\n  name: string;\n  /** One-line description */\n  brief: string;\n  /** Origin: 'server' for built-in operations, or 'skill:name', 'agent:name', etc. */\n  source: string;\n  /** CRUDE endpoint (for server operations) */\n  endpoint?: string;\n  /** Whether this capability is currently active or available to activate */\n  status: 'active' | 'available';\n}\n\n/**\n * Interface for pluggable capability providers.\n * Implement this to contribute capabilities from new sources (e.g. portfolio elements).\n * @see Issue #1760 - extensibility for portfolio element capabilities\n */\nexport interface CapabilitySource {\n  readonly sourceType: string;\n  getCapabilities(): Record<string, CapabilityEntry[]>;\n}\n\n/**\n * Built-in capability source that reads from the operation registry.\n * Groups operations by their schema-declared category field.\n */\nclass ServerOperationsSource implements CapabilitySource {\n  readonly sourceType = 'server';\n\n  getCapabilities(): Record<string, CapabilityEntry[]> {\n    const map: Record<string, CapabilityEntry[]> = {};\n\n    // Collect from OPERATION_ROUTES (the complete operation list)\n    for (const [opName, route] of Object.entries(OPERATION_ROUTES)) {\n      const schema = getAnyOperationSchema(opName);\n      const category = schema?.category || 'Other';\n      const brief = IntrospectionResolver['toBrief'](\n        schema?.description || route.description || `${opName} operation`\n      );\n\n      if (!map[category]) map[category] = [];\n      map[category].push({\n        name: opName,\n        brief,\n        source: 'server',\n        endpoint: route.endpoint,\n        status: 'active',\n      });\n    }\n\n    // Add schema-only operations not in OPERATION_ROUTES (e.g., introspect, get_capabilities)\n    for (const [opName, schema] of Object.entries(ALL_OPERATION_SCHEMAS)) {\n      if (opName in OPERATION_ROUTES) continue;\n      const category = schema.category || 'Other';\n      const brief = IntrospectionResolver['toBrief'](schema.description);\n\n      if (!map[category]) map[category] = [];\n      map[category].push({\n        name: opName,\n        brief,\n        source: 'server',\n        endpoint: schema.endpoint,\n        status: 'active',\n      });\n    }\n\n    return map;\n  }\n}\n\n/**\n * Human-readable descriptions for each capability category.\n * @see Issue #1760 - get_capabilities operation\n */\nconst CATEGORY_DESCRIPTIONS: Record<string, string> = {\n  'Element Lifecycle': 'Create, read, edit, delete, import, export, and validate elements (personas, skills, templates, agents, memories, ensembles).',\n  'Element Discovery': 'Search, list, query, and filter elements across your portfolio and connected sources.',\n  'Activation': 'Activate and deactivate elements for use in the current session.',\n  'Memory': 'Add entries to and clear memory elements.',\n  'Template Rendering': 'Render templates with variable substitution.',\n  'Agent Execution': 'Execute agents, track progress, record steps, manage handoffs, and control the execution lifecycle.',\n  'Security & Permissions': 'Confirm operations, verify challenges, evaluate CLI permissions, and manage approval workflows.',\n  'Community Collection': 'Browse, search, install from, and submit to the DollhouseMCP community collection.',\n  'Portfolio Management': 'Initialize, sync, configure, and manage your local and GitHub portfolio.',\n  'GitHub Authentication': 'Set up, check, and manage GitHub authentication and OAuth configuration.',\n  'Intelligence': 'Find similar elements, discover relationships, and search by action verbs using the capability index.',\n  'Configuration & Diagnostics': 'Manage server configuration, convert formats, query logs, metrics, and system info.',\n  'Management Console': 'Open the portfolio web UI with optional deep-linking. Supports URL parameters to pre-populate search, filter by type or log level, and navigate directly to specific elements or tabs.',\n  'System Introspection': 'Discover available operations, types, capabilities, and element format specifications.',\n};\n\n/** Registered capability sources. ServerOperationsSource is always present. */\nconst capabilitySources: CapabilitySource[] = [new ServerOperationsSource()];\n"]}