@dollhousemcp/mcp-server 1.3.2 → 1.4.0

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 (71) hide show
  1. package/CHANGELOG.md +57 -0
  2. package/README.md +100 -5
  3. package/dist/collection/ElementInstaller.d.ts.map +1 -1
  4. package/dist/collection/ElementInstaller.js +2 -4
  5. package/dist/elements/agents/AgentManager.js +2 -2
  6. package/dist/elements/index.d.ts +0 -2
  7. package/dist/elements/index.d.ts.map +1 -1
  8. package/dist/elements/index.js +1 -3
  9. package/dist/elements/skills/Skill.d.ts.map +1 -1
  10. package/dist/elements/skills/Skill.js +3 -2
  11. package/dist/elements/skills/SkillManager.d.ts +89 -0
  12. package/dist/elements/skills/SkillManager.d.ts.map +1 -0
  13. package/dist/elements/skills/SkillManager.js +412 -0
  14. package/dist/elements/skills/index.d.ts +1 -0
  15. package/dist/elements/skills/index.d.ts.map +1 -1
  16. package/dist/elements/skills/index.js +2 -1
  17. package/dist/elements/templates/TemplateManager.d.ts +9 -0
  18. package/dist/elements/templates/TemplateManager.d.ts.map +1 -1
  19. package/dist/elements/templates/TemplateManager.js +28 -1
  20. package/dist/index.d.ts +104 -1
  21. package/dist/index.d.ts.map +1 -1
  22. package/dist/index.js +1166 -6
  23. package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
  24. package/dist/portfolio/PortfolioManager.js +1 -3
  25. package/dist/portfolio/types.d.ts +6 -6
  26. package/dist/portfolio/types.d.ts.map +1 -1
  27. package/dist/portfolio/types.js +7 -7
  28. package/dist/security/audit/config/suppressions.d.ts.map +1 -1
  29. package/dist/security/audit/config/suppressions.js +6 -1
  30. package/dist/server/ServerSetup.d.ts.map +1 -1
  31. package/dist/server/ServerSetup.js +5 -2
  32. package/dist/server/tools/CollectionTools.js +6 -6
  33. package/dist/server/tools/ElementTools.d.ts +11 -0
  34. package/dist/server/tools/ElementTools.d.ts.map +1 -0
  35. package/dist/server/tools/ElementTools.js +303 -0
  36. package/dist/server/tools/index.d.ts +1 -0
  37. package/dist/server/tools/index.d.ts.map +1 -1
  38. package/dist/server/tools/index.js +2 -1
  39. package/dist/server/types.d.ts +31 -0
  40. package/dist/server/types.d.ts.map +1 -1
  41. package/dist/server/types.js +1 -1
  42. package/dist/utils/filesystem.d.ts.map +1 -1
  43. package/dist/utils/filesystem.js +17 -5
  44. package/package.json +1 -1
  45. package/dist/elements/ensembles/Ensemble.d.ts +0 -144
  46. package/dist/elements/ensembles/Ensemble.d.ts.map +0 -1
  47. package/dist/elements/ensembles/Ensemble.js +0 -860
  48. package/dist/elements/ensembles/EnsembleManager.d.ts +0 -85
  49. package/dist/elements/ensembles/EnsembleManager.d.ts.map +0 -1
  50. package/dist/elements/ensembles/EnsembleManager.js +0 -378
  51. package/dist/elements/ensembles/constants.d.ts +0 -73
  52. package/dist/elements/ensembles/constants.d.ts.map +0 -1
  53. package/dist/elements/ensembles/constants.js +0 -92
  54. package/dist/elements/ensembles/index.d.ts +0 -8
  55. package/dist/elements/ensembles/index.d.ts.map +0 -1
  56. package/dist/elements/ensembles/index.js +0 -8
  57. package/dist/elements/ensembles/types.d.ts +0 -92
  58. package/dist/elements/ensembles/types.d.ts.map +0 -1
  59. package/dist/elements/ensembles/types.js +0 -8
  60. package/dist/elements/memories/Memory.d.ts +0 -110
  61. package/dist/elements/memories/Memory.d.ts.map +0 -1
  62. package/dist/elements/memories/Memory.js +0 -470
  63. package/dist/elements/memories/MemoryManager.d.ts +0 -86
  64. package/dist/elements/memories/MemoryManager.d.ts.map +0 -1
  65. package/dist/elements/memories/MemoryManager.js +0 -435
  66. package/dist/elements/memories/constants.d.ts +0 -42
  67. package/dist/elements/memories/constants.d.ts.map +0 -1
  68. package/dist/elements/memories/constants.js +0 -49
  69. package/dist/elements/memories/index.d.ts +0 -6
  70. package/dist/elements/memories/index.d.ts.map +0 -1
  71. package/dist/elements/memories/index.js +0 -6
@@ -0,0 +1,303 @@
1
+ /**
2
+ * Element-related tool definitions and handlers
3
+ * Provides generic tools that work with all element types
4
+ */
5
+ import { ElementType } from '../../portfolio/types.js';
6
+ export function getElementTools(server) {
7
+ return [
8
+ {
9
+ tool: {
10
+ name: "list_elements",
11
+ description: "List all available elements of a specific type",
12
+ inputSchema: {
13
+ type: "object",
14
+ properties: {
15
+ type: {
16
+ type: "string",
17
+ description: "The element type to list",
18
+ enum: Object.values(ElementType),
19
+ },
20
+ },
21
+ required: ["type"],
22
+ },
23
+ },
24
+ handler: (args) => server.listElements(args.type)
25
+ },
26
+ {
27
+ tool: {
28
+ name: "activate_element",
29
+ description: "Activate a specific element by name",
30
+ inputSchema: {
31
+ type: "object",
32
+ properties: {
33
+ name: {
34
+ type: "string",
35
+ description: "The element name to activate",
36
+ },
37
+ type: {
38
+ type: "string",
39
+ description: "The element type",
40
+ enum: Object.values(ElementType),
41
+ },
42
+ },
43
+ required: ["name", "type"],
44
+ },
45
+ },
46
+ handler: (args) => server.activateElement(args.name, args.type)
47
+ },
48
+ {
49
+ tool: {
50
+ name: "get_active_elements",
51
+ description: "Get information about currently active elements of a specific type",
52
+ inputSchema: {
53
+ type: "object",
54
+ properties: {
55
+ type: {
56
+ type: "string",
57
+ description: "The element type to check",
58
+ enum: Object.values(ElementType),
59
+ },
60
+ },
61
+ required: ["type"],
62
+ },
63
+ },
64
+ handler: (args) => server.getActiveElements(args.type)
65
+ },
66
+ {
67
+ tool: {
68
+ name: "deactivate_element",
69
+ description: "Deactivate a specific element",
70
+ inputSchema: {
71
+ type: "object",
72
+ properties: {
73
+ name: {
74
+ type: "string",
75
+ description: "The element name to deactivate",
76
+ },
77
+ type: {
78
+ type: "string",
79
+ description: "The element type",
80
+ enum: Object.values(ElementType),
81
+ },
82
+ },
83
+ required: ["name", "type"],
84
+ },
85
+ },
86
+ handler: (args) => server.deactivateElement(args.name, args.type)
87
+ },
88
+ {
89
+ tool: {
90
+ name: "get_element_details",
91
+ description: "Get detailed information about a specific element",
92
+ inputSchema: {
93
+ type: "object",
94
+ properties: {
95
+ name: {
96
+ type: "string",
97
+ description: "The element name to get details for",
98
+ },
99
+ type: {
100
+ type: "string",
101
+ description: "The element type",
102
+ enum: Object.values(ElementType),
103
+ },
104
+ },
105
+ required: ["name", "type"],
106
+ },
107
+ },
108
+ handler: (args) => server.getElementDetails(args.name, args.type)
109
+ },
110
+ {
111
+ tool: {
112
+ name: "reload_elements",
113
+ description: "Reload elements of a specific type from the filesystem",
114
+ inputSchema: {
115
+ type: "object",
116
+ properties: {
117
+ type: {
118
+ type: "string",
119
+ description: "The element type to reload",
120
+ enum: Object.values(ElementType),
121
+ },
122
+ },
123
+ required: ["type"],
124
+ },
125
+ },
126
+ handler: (args) => server.reloadElements(args.type)
127
+ },
128
+ // Element-specific tools
129
+ {
130
+ tool: {
131
+ name: "render_template",
132
+ description: "Render a template element with provided variables",
133
+ inputSchema: {
134
+ type: "object",
135
+ properties: {
136
+ name: {
137
+ type: "string",
138
+ description: "The template name to render",
139
+ },
140
+ variables: {
141
+ type: "object",
142
+ description: "Variables to use in the template",
143
+ additionalProperties: true,
144
+ },
145
+ },
146
+ required: ["name", "variables"],
147
+ },
148
+ },
149
+ handler: (args) => server.renderTemplate(args.name, args.variables)
150
+ },
151
+ {
152
+ tool: {
153
+ name: "execute_agent",
154
+ description: "Execute an agent element with a specific goal",
155
+ inputSchema: {
156
+ type: "object",
157
+ properties: {
158
+ name: {
159
+ type: "string",
160
+ description: "The agent name to execute",
161
+ },
162
+ goal: {
163
+ type: "string",
164
+ description: "The goal for the agent to achieve",
165
+ },
166
+ },
167
+ required: ["name", "goal"],
168
+ },
169
+ },
170
+ handler: (args) => server.executeAgent(args.name, args.goal)
171
+ },
172
+ // Generic element creation tool
173
+ {
174
+ tool: {
175
+ name: "create_element",
176
+ description: "Create a new element of any type",
177
+ inputSchema: {
178
+ type: "object",
179
+ properties: {
180
+ name: {
181
+ type: "string",
182
+ description: "The element name",
183
+ },
184
+ type: {
185
+ type: "string",
186
+ description: "The element type",
187
+ enum: Object.values(ElementType),
188
+ },
189
+ description: {
190
+ type: "string",
191
+ description: "Element description",
192
+ },
193
+ content: {
194
+ type: "string",
195
+ description: "Element content (required for some types)",
196
+ },
197
+ metadata: {
198
+ type: "object",
199
+ description: "Additional metadata specific to element type",
200
+ additionalProperties: true,
201
+ },
202
+ },
203
+ required: ["name", "type", "description"],
204
+ },
205
+ },
206
+ handler: (args) => server.createElement(args)
207
+ },
208
+ // Generic element editing tool
209
+ {
210
+ tool: {
211
+ name: "edit_element",
212
+ description: "Edit an existing element of any type",
213
+ inputSchema: {
214
+ type: "object",
215
+ properties: {
216
+ name: {
217
+ type: "string",
218
+ description: "The element name to edit",
219
+ },
220
+ type: {
221
+ type: "string",
222
+ description: "The element type",
223
+ enum: Object.values(ElementType),
224
+ },
225
+ field: {
226
+ type: "string",
227
+ description: "The field to edit (e.g., 'description', 'metadata.author', 'content')",
228
+ },
229
+ value: {
230
+ description: "The new value for the field",
231
+ oneOf: [
232
+ { type: "string" },
233
+ { type: "number" },
234
+ { type: "boolean" },
235
+ { type: "object" },
236
+ { type: "array" },
237
+ ],
238
+ },
239
+ },
240
+ required: ["name", "type", "field", "value"],
241
+ },
242
+ },
243
+ handler: (args) => server.editElement(args)
244
+ },
245
+ // Generic element validation tool
246
+ {
247
+ tool: {
248
+ name: "validate_element",
249
+ description: "Validate an element for correctness and best practices",
250
+ inputSchema: {
251
+ type: "object",
252
+ properties: {
253
+ name: {
254
+ type: "string",
255
+ description: "The element name to validate",
256
+ },
257
+ type: {
258
+ type: "string",
259
+ description: "The element type",
260
+ enum: Object.values(ElementType),
261
+ },
262
+ strict: {
263
+ type: "boolean",
264
+ description: "Whether to apply strict validation rules",
265
+ default: false,
266
+ },
267
+ },
268
+ required: ["name", "type"],
269
+ },
270
+ },
271
+ handler: (args) => server.validateElement(args)
272
+ },
273
+ // Generic element deletion tool
274
+ {
275
+ tool: {
276
+ name: "delete_element",
277
+ description: "Delete an element and optionally its associated data files",
278
+ inputSchema: {
279
+ type: "object",
280
+ properties: {
281
+ name: {
282
+ type: "string",
283
+ description: "The element name to delete",
284
+ },
285
+ type: {
286
+ type: "string",
287
+ description: "The element type",
288
+ enum: Object.values(ElementType),
289
+ },
290
+ deleteData: {
291
+ type: "boolean",
292
+ description: "Whether to delete associated data files (if not specified, will prompt)",
293
+ default: undefined,
294
+ },
295
+ },
296
+ required: ["name", "type"],
297
+ },
298
+ },
299
+ handler: (args) => server.deleteElement(args)
300
+ },
301
+ ];
302
+ }
303
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElementTools.js","sourceRoot":"","sources":["../../../src/server/tools/ElementTools.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Element-related tool definitions and handlers\n * Provides generic tools that work with all element types\n */\n\nimport { ToolDefinition } from './ToolRegistry.js';\nimport { IToolHandler } from '../types.js';\nimport { ElementType } from '../../portfolio/types.js';\n\n// Type-safe interfaces for all element tool arguments\ninterface ListElementsArgs {\n  type: string;\n}\n\ninterface ActivateElementArgs {\n  name: string;\n  type: string;\n}\n\ninterface DeactivateElementArgs {\n  name: string;\n  type: string;\n}\n\ninterface GetElementDetailsArgs {\n  name: string;\n  type: string;\n}\n\ninterface GetActiveElementsArgs {\n  type: string;\n}\n\ninterface CreateElementArgs {\n  name: string;\n  description: string;\n  type: string;\n  content?: string;\n  metadata?: Record<string, any>;\n}\n\ninterface EditElementArgs {\n  name: string;\n  type: string;\n  field: string;\n  value: any;\n}\n\ninterface ValidateElementArgs {\n  name: string;\n  type: string;\n  strict?: boolean;\n}\n\ninterface DeleteElementArgs {\n  name: string;\n  type: string;\n  deleteData?: boolean;\n}\n\ninterface RenderTemplateArgs {\n  name: string;\n  variables: Record<string, any>;\n}\n\ninterface ReloadElementsArgs {\n  type: string;\n}\n\ninterface ExecuteAgentArgs {\n  name: string;\n  goal: string;\n}\n\nexport function getElementTools(server: IToolHandler): Array<{ tool: ToolDefinition; handler: any }> {\n  return [\n    {\n      tool: {\n        name: \"list_elements\",\n        description: \"List all available elements of a specific type\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            type: {\n              type: \"string\",\n              description: \"The element type to list\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"type\"],\n        },\n      },\n      handler: (args: ListElementsArgs) => server.listElements(args.type)\n    },\n    {\n      tool: {\n        name: \"activate_element\",\n        description: \"Activate a specific element by name\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to activate\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"name\", \"type\"],\n        },\n      },\n      handler: (args: ActivateElementArgs) => server.activateElement(args.name, args.type)\n    },\n    {\n      tool: {\n        name: \"get_active_elements\",\n        description: \"Get information about currently active elements of a specific type\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            type: {\n              type: \"string\",\n              description: \"The element type to check\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"type\"],\n        },\n      },\n      handler: (args: GetActiveElementsArgs) => server.getActiveElements(args.type)\n    },\n    {\n      tool: {\n        name: \"deactivate_element\",\n        description: \"Deactivate a specific element\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to deactivate\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"name\", \"type\"],\n        },\n      },\n      handler: (args: DeactivateElementArgs) => server.deactivateElement(args.name, args.type)\n    },\n    {\n      tool: {\n        name: \"get_element_details\",\n        description: \"Get detailed information about a specific element\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to get details for\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"name\", \"type\"],\n        },\n      },\n      handler: (args: GetElementDetailsArgs) => server.getElementDetails(args.name, args.type)\n    },\n    {\n      tool: {\n        name: \"reload_elements\",\n        description: \"Reload elements of a specific type from the filesystem\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            type: {\n              type: \"string\",\n              description: \"The element type to reload\",\n              enum: Object.values(ElementType),\n            },\n          },\n          required: [\"type\"],\n        },\n      },\n      handler: (args: ReloadElementsArgs) => server.reloadElements(args.type)\n    },\n    // Element-specific tools\n    {\n      tool: {\n        name: \"render_template\",\n        description: \"Render a template element with provided variables\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The template name to render\",\n            },\n            variables: {\n              type: \"object\",\n              description: \"Variables to use in the template\",\n              additionalProperties: true,\n            },\n          },\n          required: [\"name\", \"variables\"],\n        },\n      },\n      handler: (args: RenderTemplateArgs) => server.renderTemplate(args.name, args.variables)\n    },\n    {\n      tool: {\n        name: \"execute_agent\",\n        description: \"Execute an agent element with a specific goal\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The agent name to execute\",\n            },\n            goal: {\n              type: \"string\",\n              description: \"The goal for the agent to achieve\",\n            },\n          },\n          required: [\"name\", \"goal\"],\n        },\n      },\n      handler: (args: ExecuteAgentArgs) => server.executeAgent(args.name, args.goal)\n    },\n    // Generic element creation tool\n    {\n      tool: {\n        name: \"create_element\",\n        description: \"Create a new element of any type\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n            description: {\n              type: \"string\",\n              description: \"Element description\",\n            },\n            content: {\n              type: \"string\",\n              description: \"Element content (required for some types)\",\n            },\n            metadata: {\n              type: \"object\",\n              description: \"Additional metadata specific to element type\",\n              additionalProperties: true,\n            },\n          },\n          required: [\"name\", \"type\", \"description\"],\n        },\n      },\n      handler: (args: CreateElementArgs) => server.createElement(args)\n    },\n    // Generic element editing tool\n    {\n      tool: {\n        name: \"edit_element\",\n        description: \"Edit an existing element of any type\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to edit\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n            field: {\n              type: \"string\",\n              description: \"The field to edit (e.g., 'description', 'metadata.author', 'content')\",\n            },\n            value: {\n              description: \"The new value for the field\",\n              oneOf: [\n                { type: \"string\" },\n                { type: \"number\" },\n                { type: \"boolean\" },\n                { type: \"object\" },\n                { type: \"array\" },\n              ],\n            },\n          },\n          required: [\"name\", \"type\", \"field\", \"value\"],\n        },\n      },\n      handler: (args: EditElementArgs) => server.editElement(args)\n    },\n    // Generic element validation tool\n    {\n      tool: {\n        name: \"validate_element\",\n        description: \"Validate an element for correctness and best practices\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to validate\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n            strict: {\n              type: \"boolean\",\n              description: \"Whether to apply strict validation rules\",\n              default: false,\n            },\n          },\n          required: [\"name\", \"type\"],\n        },\n      },\n      handler: (args: ValidateElementArgs) => server.validateElement(args)\n    },\n    // Generic element deletion tool\n    {\n      tool: {\n        name: \"delete_element\",\n        description: \"Delete an element and optionally its associated data files\",\n        inputSchema: {\n          type: \"object\",\n          properties: {\n            name: {\n              type: \"string\",\n              description: \"The element name to delete\",\n            },\n            type: {\n              type: \"string\",\n              description: \"The element type\",\n              enum: Object.values(ElementType),\n            },\n            deleteData: {\n              type: \"boolean\",\n              description: \"Whether to delete associated data files (if not specified, will prompt)\",\n              default: undefined,\n            },\n          },\n          required: [\"name\", \"type\"],\n        },\n      },\n      handler: (args: DeleteElementArgs) => server.deleteElement(args)\n    },\n  ];\n}"]}
@@ -3,6 +3,7 @@
3
3
  */
4
4
  export * from './ToolRegistry.js';
5
5
  export * from './PersonaTools.js';
6
+ export * from './ElementTools.js';
6
7
  export * from './CollectionTools.js';
7
8
  export * from './UserTools.js';
8
9
  export * from './UpdateTools.js';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/server/tools/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/server/tools/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC"}
@@ -3,8 +3,9 @@
3
3
  */
4
4
  export * from './ToolRegistry.js';
5
5
  export * from './PersonaTools.js';
6
+ export * from './ElementTools.js';
6
7
  export * from './CollectionTools.js';
7
8
  export * from './UserTools.js';
8
9
  export * from './UpdateTools.js';
9
10
  export * from './ConfigTools.js';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmVyL3Rvb2xzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4cG9ydCBhbGwgdG9vbCBtb2R1bGVzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9Ub29sUmVnaXN0cnkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9QZXJzb25hVG9vbHMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9Db2xsZWN0aW9uVG9vbHMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9Vc2VyVG9vbHMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9VcGRhdGVUb29scy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0NvbmZpZ1Rvb2xzLmpzJzsiXX0=
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmVyL3Rvb2xzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXhwb3J0IGFsbCB0b29sIG1vZHVsZXNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL1Rvb2xSZWdpc3RyeS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL1BlcnNvbmFUb29scy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0VsZW1lbnRUb29scy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0NvbGxlY3Rpb25Ub29scy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL1VzZXJUb29scy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL1VwZGF0ZVRvb2xzLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vQ29uZmlnVG9vbHMuanMnOyJdfQ==
@@ -11,6 +11,37 @@ export interface IToolHandler {
11
11
  createPersona(name: string, description: string, category: string, instructions: string, triggers?: string): Promise<any>;
12
12
  editPersona(persona: string, field: string, value: string): Promise<any>;
13
13
  validatePersona(persona: string): Promise<any>;
14
+ listElements(type: string): Promise<any>;
15
+ activateElement(name: string, type: string): Promise<any>;
16
+ getActiveElements(type: string): Promise<any>;
17
+ deactivateElement(name: string, type: string): Promise<any>;
18
+ getElementDetails(name: string, type: string): Promise<any>;
19
+ reloadElements(type: string): Promise<any>;
20
+ createElement(args: {
21
+ name: string;
22
+ type: string;
23
+ description: string;
24
+ content?: string;
25
+ metadata?: Record<string, any>;
26
+ }): Promise<any>;
27
+ editElement(args: {
28
+ name: string;
29
+ type: string;
30
+ field: string;
31
+ value: any;
32
+ }): Promise<any>;
33
+ validateElement(args: {
34
+ name: string;
35
+ type: string;
36
+ strict?: boolean;
37
+ }): Promise<any>;
38
+ deleteElement(args: {
39
+ name: string;
40
+ type: string;
41
+ deleteData?: boolean;
42
+ }): Promise<any>;
43
+ renderTemplate(name: string, variables: Record<string, any>): Promise<any>;
44
+ executeAgent(name: string, goal: string): Promise<any>;
14
45
  browseCollection(section?: string, type?: string): Promise<any>;
15
46
  searchCollection(query: string): Promise<any>;
16
47
  getCollectionContent(path: string): Promise<any>;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/server/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,YAAY;IAE3B,YAAY,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAC7B,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC/C,gBAAgB,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IACjC,iBAAiB,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAClC,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACjD,cAAc,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAC/B,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1H,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACzE,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAG/C,gBAAgB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAChE,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC9C,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACjD,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3C,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAG7C,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAChE,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAChC,iBAAiB,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAGlC,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAChC,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC7C,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC/C,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAGhC,kBAAkB,CAAC,MAAM,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC9C,kBAAkB,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC;IAGnC,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC7C,iBAAiB,CAAC,eAAe,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3D,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACjE,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACjE,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CAC/D"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/server/types.ts"],"names":[],"mappings":"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"}
@@ -2,4 +2,4 @@
2
2
  * Server interface types to avoid circular dependencies
3
3
  */
4
4
  export {};
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmVyL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTZXJ2ZXIgaW50ZXJmYWNlIHR5cGVzIHRvIGF2b2lkIGNpcmN1bGFyIGRlcGVuZGVuY2llc1xuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRvb2xIYW5kbGVyIHtcbiAgLy8gUGVyc29uYSB0b29sc1xuICBsaXN0UGVyc29uYXMoKTogUHJvbWlzZTxhbnk+O1xuICBhY3RpdmF0ZVBlcnNvbmEocGVyc29uYTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBnZXRBY3RpdmVQZXJzb25hKCk6IFByb21pc2U8YW55PjtcbiAgZGVhY3RpdmF0ZVBlcnNvbmEoKTogUHJvbWlzZTxhbnk+O1xuICBnZXRQZXJzb25hRGV0YWlscyhwZXJzb25hOiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIHJlbG9hZFBlcnNvbmFzKCk6IFByb21pc2U8YW55PjtcbiAgY3JlYXRlUGVyc29uYShuYW1lOiBzdHJpbmcsIGRlc2NyaXB0aW9uOiBzdHJpbmcsIGNhdGVnb3J5OiBzdHJpbmcsIGluc3RydWN0aW9uczogc3RyaW5nLCB0cmlnZ2Vycz86IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgZWRpdFBlcnNvbmEocGVyc29uYTogc3RyaW5nLCBmaWVsZDogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICB2YWxpZGF0ZVBlcnNvbmEocGVyc29uYTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBcbiAgLy8gQ29sbGVjdGlvbiB0b29sc1xuICBicm93c2VDb2xsZWN0aW9uKHNlY3Rpb24/OiBzdHJpbmcsIHR5cGU/OiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIHNlYXJjaENvbGxlY3Rpb24ocXVlcnk6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgZ2V0Q29sbGVjdGlvbkNvbnRlbnQocGF0aDogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBpbnN0YWxsQ29udGVudChwYXRoOiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIHN1Ym1pdENvbnRlbnQoY29udGVudDogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBcbiAgLy8gVXNlciB0b29sc1xuICBzZXRVc2VySWRlbnRpdHkodXNlcm5hbWU6IHN0cmluZywgZW1haWw/OiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGdldFVzZXJJZGVudGl0eSgpOiBQcm9taXNlPGFueT47XG4gIGNsZWFyVXNlcklkZW50aXR5KCk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIFVwZGF0ZSB0b29sc1xuICBjaGVja0ZvclVwZGF0ZXMoKTogUHJvbWlzZTxhbnk+O1xuICB1cGRhdGVTZXJ2ZXIoY29uZmlybTogYm9vbGVhbik6IFByb21pc2U8YW55PjtcbiAgcm9sbGJhY2tVcGRhdGUoY29uZmlybTogYm9vbGVhbik6IFByb21pc2U8YW55PjtcbiAgZ2V0U2VydmVyU3RhdHVzKCk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIENvbmZpZyB0b29sc1xuICBjb25maWd1cmVJbmRpY2F0b3IoY29uZmlnOiBhbnkpOiBQcm9taXNlPGFueT47XG4gIGdldEluZGljYXRvckNvbmZpZygpOiBQcm9taXNlPGFueT47XG4gIFxuICAvLyBFeHBvcnQvSW1wb3J0L1NoYXJlIHRvb2xzXG4gIGV4cG9ydFBlcnNvbmEocGVyc29uYTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBleHBvcnRBbGxQZXJzb25hcyhpbmNsdWRlRGVmYXVsdHM/OiBib29sZWFuKTogUHJvbWlzZTxhbnk+O1xuICBpbXBvcnRQZXJzb25hKHNvdXJjZTogc3RyaW5nLCBvdmVyd3JpdGU/OiBib29sZWFuKTogUHJvbWlzZTxhbnk+O1xuICBzaGFyZVBlcnNvbmEocGVyc29uYTogc3RyaW5nLCBleHBpcnlEYXlzPzogbnVtYmVyKTogUHJvbWlzZTxhbnk+O1xuICBpbXBvcnRGcm9tVXJsKHVybDogc3RyaW5nLCBvdmVyd3JpdGU/OiBib29sZWFuKTogUHJvbWlzZTxhbnk+O1xufSJdfQ==
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmVyL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTZXJ2ZXIgaW50ZXJmYWNlIHR5cGVzIHRvIGF2b2lkIGNpcmN1bGFyIGRlcGVuZGVuY2llc1xuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRvb2xIYW5kbGVyIHtcbiAgLy8gUGVyc29uYSB0b29scyAobGVnYWN5IC0gd2lsbCBjYWxsIGVsZW1lbnQgdG9vbHMgaW50ZXJuYWxseSlcbiAgbGlzdFBlcnNvbmFzKCk6IFByb21pc2U8YW55PjtcbiAgYWN0aXZhdGVQZXJzb25hKHBlcnNvbmE6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgZ2V0QWN0aXZlUGVyc29uYSgpOiBQcm9taXNlPGFueT47XG4gIGRlYWN0aXZhdGVQZXJzb25hKCk6IFByb21pc2U8YW55PjtcbiAgZ2V0UGVyc29uYURldGFpbHMocGVyc29uYTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICByZWxvYWRQZXJzb25hcygpOiBQcm9taXNlPGFueT47XG4gIGNyZWF0ZVBlcnNvbmEobmFtZTogc3RyaW5nLCBkZXNjcmlwdGlvbjogc3RyaW5nLCBjYXRlZ29yeTogc3RyaW5nLCBpbnN0cnVjdGlvbnM6IHN0cmluZywgdHJpZ2dlcnM/OiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGVkaXRQZXJzb25hKHBlcnNvbmE6IHN0cmluZywgZmllbGQ6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgdmFsaWRhdGVQZXJzb25hKHBlcnNvbmE6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIEVsZW1lbnQgdG9vbHMgKGdlbmVyaWMgZm9yIGFsbCBlbGVtZW50IHR5cGVzKVxuICBsaXN0RWxlbWVudHModHlwZTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBhY3RpdmF0ZUVsZW1lbnQobmFtZTogc3RyaW5nLCB0eXBlOiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGdldEFjdGl2ZUVsZW1lbnRzKHR5cGU6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgZGVhY3RpdmF0ZUVsZW1lbnQobmFtZTogc3RyaW5nLCB0eXBlOiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGdldEVsZW1lbnREZXRhaWxzKG5hbWU6IHN0cmluZywgdHlwZTogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICByZWxvYWRFbGVtZW50cyh0eXBlOiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGNyZWF0ZUVsZW1lbnQoYXJnczoge25hbWU6IHN0cmluZzsgdHlwZTogc3RyaW5nOyBkZXNjcmlwdGlvbjogc3RyaW5nOyBjb250ZW50Pzogc3RyaW5nOyBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT59KTogUHJvbWlzZTxhbnk+O1xuICBlZGl0RWxlbWVudChhcmdzOiB7bmFtZTogc3RyaW5nOyB0eXBlOiBzdHJpbmc7IGZpZWxkOiBzdHJpbmc7IHZhbHVlOiBhbnl9KTogUHJvbWlzZTxhbnk+O1xuICB2YWxpZGF0ZUVsZW1lbnQoYXJnczoge25hbWU6IHN0cmluZzsgdHlwZTogc3RyaW5nOyBzdHJpY3Q/OiBib29sZWFufSk6IFByb21pc2U8YW55PjtcbiAgZGVsZXRlRWxlbWVudChhcmdzOiB7bmFtZTogc3RyaW5nOyB0eXBlOiBzdHJpbmc7IGRlbGV0ZURhdGE/OiBib29sZWFufSk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIEVsZW1lbnQtc3BlY2lmaWMgdG9vbHNcbiAgcmVuZGVyVGVtcGxhdGUobmFtZTogc3RyaW5nLCB2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIGFueT4pOiBQcm9taXNlPGFueT47XG4gIGV4ZWN1dGVBZ2VudChuYW1lOiBzdHJpbmcsIGdvYWw6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIENvbGxlY3Rpb24gdG9vbHNcbiAgYnJvd3NlQ29sbGVjdGlvbihzZWN0aW9uPzogc3RyaW5nLCB0eXBlPzogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBzZWFyY2hDb2xsZWN0aW9uKHF1ZXJ5OiBzdHJpbmcpOiBQcm9taXNlPGFueT47XG4gIGdldENvbGxlY3Rpb25Db250ZW50KHBhdGg6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgaW5zdGFsbENvbnRlbnQocGF0aDogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBzdWJtaXRDb250ZW50KGNvbnRlbnQ6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgXG4gIC8vIFVzZXIgdG9vbHNcbiAgc2V0VXNlcklkZW50aXR5KHVzZXJuYW1lOiBzdHJpbmcsIGVtYWlsPzogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICBnZXRVc2VySWRlbnRpdHkoKTogUHJvbWlzZTxhbnk+O1xuICBjbGVhclVzZXJJZGVudGl0eSgpOiBQcm9taXNlPGFueT47XG4gIFxuICAvLyBVcGRhdGUgdG9vbHNcbiAgY2hlY2tGb3JVcGRhdGVzKCk6IFByb21pc2U8YW55PjtcbiAgdXBkYXRlU2VydmVyKGNvbmZpcm06IGJvb2xlYW4pOiBQcm9taXNlPGFueT47XG4gIHJvbGxiYWNrVXBkYXRlKGNvbmZpcm06IGJvb2xlYW4pOiBQcm9taXNlPGFueT47XG4gIGdldFNlcnZlclN0YXR1cygpOiBQcm9taXNlPGFueT47XG4gIFxuICAvLyBDb25maWcgdG9vbHNcbiAgY29uZmlndXJlSW5kaWNhdG9yKGNvbmZpZzogYW55KTogUHJvbWlzZTxhbnk+O1xuICBnZXRJbmRpY2F0b3JDb25maWcoKTogUHJvbWlzZTxhbnk+O1xuICBcbiAgLy8gRXhwb3J0L0ltcG9ydC9TaGFyZSB0b29sc1xuICBleHBvcnRQZXJzb25hKHBlcnNvbmE6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgZXhwb3J0QWxsUGVyc29uYXMoaW5jbHVkZURlZmF1bHRzPzogYm9vbGVhbik6IFByb21pc2U8YW55PjtcbiAgaW1wb3J0UGVyc29uYShzb3VyY2U6IHN0cmluZywgb3ZlcndyaXRlPzogYm9vbGVhbik6IFByb21pc2U8YW55PjtcbiAgc2hhcmVQZXJzb25hKHBlcnNvbmE6IHN0cmluZywgZXhwaXJ5RGF5cz86IG51bWJlcik6IFByb21pc2U8YW55PjtcbiAgaW1wb3J0RnJvbVVybCh1cmw6IHN0cmluZywgb3ZlcndyaXRlPzogYm9vbGVhbik6IFByb21pc2U8YW55Pjtcbn0iXX0=
@@ -1 +1 @@
1
- {"version":3,"file":"filesystem.d.ts","sourceRoot":"","sources":["../../src/utils/filesystem.ts"],"names":[],"mappings":"AAAA;;GAEG;AAMH;;GAEG;AACH,wBAAgB,mBAAmB,IAAI,MAAM,CAK5C;AAQD,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAkB7E;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAW5C;AAED;;GAEG;AACH,wBAAsB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAMpE;AAED;;GAEG;AACH,wBAAsB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAOnE;AAED;;GAEG;AACH,wBAAsB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAGnE;AAED;;GAEG;AACH,wBAAsB,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAOxF"}
1
+ {"version":3,"file":"filesystem.d.ts","sourceRoot":"","sources":["../../src/utils/filesystem.ts"],"names":[],"mappings":"AAAA;;GAEG;AAMH;;GAEG;AACH,wBAAgB,mBAAmB,IAAI,MAAM,CAK5C;AAQD,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAkB7E;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CA0B5C;AAED;;GAEG;AACH,wBAAsB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAMpE;AAED;;GAEG;AACH,wBAAsB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAOnE;AAED;;GAEG;AACH,wBAAsB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAGnE;AAED;;GAEG;AACH,wBAAsB,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAOxF"}
@@ -44,12 +44,24 @@ export function slugify(text) {
44
44
  // Previously: Multiple replace() operations with unbounded quantifiers could cause exponential backtracking
45
45
  // Now: Single-pass transformation with built-in length limit
46
46
  const normalized = text.toLowerCase();
47
- return normalized
47
+ const transformed = normalized
48
48
  .split('')
49
49
  .map(char => ALPHANUMERIC_REGEX.test(char) ? char : '-')
50
- .join('')
51
- .replace(/^-+|-+$/g, '') // Only trim leading/trailing hyphens
52
- .replace(/-{2,}/g, '-'); // Collapse multiple hyphens
50
+ .join('');
51
+ // SECURITY FIX: Avoid polynomial regex by using separate operations
52
+ // Trim leading hyphens
53
+ let start = 0;
54
+ while (start < transformed.length && transformed[start] === '-') {
55
+ start++;
56
+ }
57
+ // Trim trailing hyphens
58
+ let end = transformed.length - 1;
59
+ while (end >= start && transformed[end] === '-') {
60
+ end--;
61
+ }
62
+ // Extract the trimmed portion and collapse multiple hyphens
63
+ const trimmed = transformed.slice(start, end + 1);
64
+ return trimmed.replace(/-{2,}/g, '-'); // This is safe as it's linear
53
65
  }
54
66
  /**
55
67
  * Ensure a directory exists, create if it doesn't
@@ -91,4 +103,4 @@ export async function createBackup(sourcePath, backupPath) {
91
103
  // Copy directory recursively
92
104
  await fs.cp(sourcePath, backupPath, { recursive: true });
93
105
  }
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filesystem.js","sourceRoot":"","sources":["../../src/utils/filesystem.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Filesystem and string manipulation utilities\n */\n\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { ADJECTIVES, ANIMALS } from '../config/constants.js';\n\n/**\n * Generate an anonymous ID for users without identity\n */\nexport function generateAnonymousId(): string {\n  const adjective = ADJECTIVES[Math.floor(Math.random() * ADJECTIVES.length)];\n  const animal = ANIMALS[Math.floor(Math.random() * ANIMALS.length)];\n  const random = Math.random().toString(36).substring(2, 6);\n  return `anon-${adjective}-${animal}-${random}`;\n}\n\n/**\n * Generate a unique ID for personas\n */\n// Pre-compiled regex for better performance (avoids creating regex on each character)\nconst ALPHANUMERIC_REGEX = /[a-z0-9]/;\n\nexport function generateUniqueId(personaName: string, author?: string): string {\n  const now = new Date();\n  const dateStr = now.toISOString().slice(0, 10).replace(/-/g, '');\n  const timeStr = now.toTimeString().slice(0, 8).replace(/:/g, '');\n  // SECURITY FIX: Prevent ReDoS by using a single-pass approach\n  // Previously: Multiple replace() operations with unbounded quantifiers could cause exponential backtracking\n  // Now: Single-pass transformation with built-in length limit\n  const normalized = personaName.toLowerCase();\n  const sanitizedName = normalized\n    .split('')\n    .map(char => ALPHANUMERIC_REGEX.test(char) ? char : '-')\n    .join('')\n    .substring(0, 100) // Limit after transformation to preserve structure\n    .replace(/^-+|-+$/g, '') // Only trim leading/trailing hyphens\n    .replace(/-{2,}/g, '-'); // Collapse multiple hyphens\n  const whoMadeIt = author || generateAnonymousId();\n  \n  return `${sanitizedName}_${dateStr}-${timeStr}_${whoMadeIt}`;\n}\n\n/**\n * Convert text to URL-safe slug\n */\nexport function slugify(text: string): string {\n  // SECURITY FIX: Prevent ReDoS by using a single-pass approach\n  // Previously: Multiple replace() operations with unbounded quantifiers could cause exponential backtracking\n  // Now: Single-pass transformation with built-in length limit\n  const normalized = text.toLowerCase();\n  return normalized\n    .split('')\n    .map(char => ALPHANUMERIC_REGEX.test(char) ? char : '-')\n    .join('')\n    .replace(/^-+|-+$/g, '') // Only trim leading/trailing hyphens\n    .replace(/-{2,}/g, '-'); // Collapse multiple hyphens\n}\n\n/**\n * Ensure a directory exists, create if it doesn't\n */\nexport async function ensureDirectory(dirPath: string): Promise<void> {\n  try {\n    await fs.access(dirPath);\n  } catch {\n    await fs.mkdir(dirPath, { recursive: true });\n  }\n}\n\n/**\n * Check if a file exists\n */\nexport async function fileExists(filePath: string): Promise<boolean> {\n  try {\n    await fs.access(filePath);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Get file size in bytes\n */\nexport async function getFileSize(filePath: string): Promise<number> {\n  const stats = await fs.stat(filePath);\n  return stats.size;\n}\n\n/**\n * Create a backup of a directory\n */\nexport async function createBackup(sourcePath: string, backupPath: string): Promise<void> {\n  // Ensure backup directory exists\n  const backupDir = path.dirname(backupPath);\n  await ensureDirectory(backupDir);\n  \n  // Copy directory recursively\n  await fs.cp(sourcePath, backupPath, { recursive: true });\n}"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filesystem.js","sourceRoot":"","sources":["../../src/utils/filesystem.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Filesystem and string manipulation utilities\n */\n\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { ADJECTIVES, ANIMALS } from '../config/constants.js';\n\n/**\n * Generate an anonymous ID for users without identity\n */\nexport function generateAnonymousId(): string {\n  const adjective = ADJECTIVES[Math.floor(Math.random() * ADJECTIVES.length)];\n  const animal = ANIMALS[Math.floor(Math.random() * ANIMALS.length)];\n  const random = Math.random().toString(36).substring(2, 6);\n  return `anon-${adjective}-${animal}-${random}`;\n}\n\n/**\n * Generate a unique ID for personas\n */\n// Pre-compiled regex for better performance (avoids creating regex on each character)\nconst ALPHANUMERIC_REGEX = /[a-z0-9]/;\n\nexport function generateUniqueId(personaName: string, author?: string): string {\n  const now = new Date();\n  const dateStr = now.toISOString().slice(0, 10).replace(/-/g, '');\n  const timeStr = now.toTimeString().slice(0, 8).replace(/:/g, '');\n  // SECURITY FIX: Prevent ReDoS by using a single-pass approach\n  // Previously: Multiple replace() operations with unbounded quantifiers could cause exponential backtracking\n  // Now: Single-pass transformation with built-in length limit\n  const normalized = personaName.toLowerCase();\n  const sanitizedName = normalized\n    .split('')\n    .map(char => ALPHANUMERIC_REGEX.test(char) ? char : '-')\n    .join('')\n    .substring(0, 100) // Limit after transformation to preserve structure\n    .replace(/^-+|-+$/g, '') // Only trim leading/trailing hyphens\n    .replace(/-{2,}/g, '-'); // Collapse multiple hyphens\n  const whoMadeIt = author || generateAnonymousId();\n  \n  return `${sanitizedName}_${dateStr}-${timeStr}_${whoMadeIt}`;\n}\n\n/**\n * Convert text to URL-safe slug\n */\nexport function slugify(text: string): string {\n  // SECURITY FIX: Prevent ReDoS by using a single-pass approach\n  // Previously: Multiple replace() operations with unbounded quantifiers could cause exponential backtracking\n  // Now: Single-pass transformation with built-in length limit\n  const normalized = text.toLowerCase();\n  const transformed = normalized\n    .split('')\n    .map(char => ALPHANUMERIC_REGEX.test(char) ? char : '-')\n    .join('');\n  \n  // SECURITY FIX: Avoid polynomial regex by using separate operations\n  // Trim leading hyphens\n  let start = 0;\n  while (start < transformed.length && transformed[start] === '-') {\n    start++;\n  }\n  \n  // Trim trailing hyphens\n  let end = transformed.length - 1;\n  while (end >= start && transformed[end] === '-') {\n    end--;\n  }\n  \n  // Extract the trimmed portion and collapse multiple hyphens\n  const trimmed = transformed.slice(start, end + 1);\n  return trimmed.replace(/-{2,}/g, '-'); // This is safe as it's linear\n}\n\n/**\n * Ensure a directory exists, create if it doesn't\n */\nexport async function ensureDirectory(dirPath: string): Promise<void> {\n  try {\n    await fs.access(dirPath);\n  } catch {\n    await fs.mkdir(dirPath, { recursive: true });\n  }\n}\n\n/**\n * Check if a file exists\n */\nexport async function fileExists(filePath: string): Promise<boolean> {\n  try {\n    await fs.access(filePath);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Get file size in bytes\n */\nexport async function getFileSize(filePath: string): Promise<number> {\n  const stats = await fs.stat(filePath);\n  return stats.size;\n}\n\n/**\n * Create a backup of a directory\n */\nexport async function createBackup(sourcePath: string, backupPath: string): Promise<void> {\n  // Ensure backup directory exists\n  const backupDir = path.dirname(backupPath);\n  await ensureDirectory(backupDir);\n  \n  // Copy directory recursively\n  await fs.cp(sourcePath, backupPath, { recursive: true });\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dollhousemcp/mcp-server",
3
- "version": "1.3.2",
3
+ "version": "1.4.0",
4
4
  "description": "DollhouseMCP - A Model Context Protocol (MCP) server that enables dynamic AI persona management from markdown files, allowing Claude and other compatible AI assistants to activate and switch between different behavioral personas.",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",