claude-flow-novice 2.14.14 → 2.14.16

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.
@@ -0,0 +1,459 @@
1
+ /**
2
+ * Skill-based MCP Selection System
3
+ * Automatically selects MCP servers based on agent skills and requirements
4
+ */ const fs = require('fs').promises;
5
+ const path = require('path');
6
+ const AgentTokenManager = require('../cli/agent-token-manager.js');
7
+ let SkillMCPSelector = class SkillMCPSelector {
8
+ constructor(options = {}){
9
+ this.tokenManager = new AgentTokenManager(options);
10
+ this.agentConfigPath = options.agentConfigPath || './config/agent-whitelist.json';
11
+ this.skillConfigPath = options.skillConfigPath || './config/skill-requirements.json';
12
+ this.mcpServersPath = options.mcpServersPath || './config/mcp-servers.json';
13
+ this.agentWhitelist = new Map();
14
+ this.skillRequirements = new Map();
15
+ this.mcpServers = new Map();
16
+ }
17
+ async initialize() {
18
+ await this.tokenManager.initialize();
19
+ await this.loadConfigurations();
20
+ console.log('[SkillMCPSelector] Initialized successfully');
21
+ }
22
+ async loadConfigurations() {
23
+ // Load agent whitelist
24
+ const agentConfig = await this.loadJson(this.agentConfigPath);
25
+ this.agentWhitelist.clear();
26
+ for (const agent of agentConfig.agents){
27
+ this.agentWhitelist.set(agent.type, agent);
28
+ }
29
+ // Load skill requirements
30
+ const skillConfig = await this.loadJson(this.skillConfigPath);
31
+ this.skillRequirements.clear();
32
+ for (const [tool, requirements] of Object.entries(skillConfig.tools)){
33
+ this.skillRequirements.set(tool, requirements);
34
+ }
35
+ // Load MCP server configurations
36
+ try {
37
+ const mcpConfig = await this.loadJson(this.mcpServersPath);
38
+ for (const [name, config] of Object.entries(mcpConfig.servers)){
39
+ this.mcpServers.set(name, config);
40
+ }
41
+ } catch (error) {
42
+ console.warn('[SkillMCPSelector] MCP servers config not found, using defaults');
43
+ this.initializeDefaultMCPServers();
44
+ }
45
+ }
46
+ async loadJson(filePath) {
47
+ const resolvedPath = path.resolve(filePath);
48
+ const content = await fs.readFile(resolvedPath, 'utf8');
49
+ return JSON.parse(content);
50
+ }
51
+ initializeDefaultMCPServers() {
52
+ // Default MCP server configurations
53
+ const defaultServers = {
54
+ 'playwright': {
55
+ name: 'playwright',
56
+ displayName: 'Playwright Browser Automation',
57
+ description: 'Browser automation and screenshot capabilities',
58
+ containerImage: 'claude-flow-novice:mcp-playwright',
59
+ tools: [
60
+ 'take_screenshot',
61
+ 'search_google',
62
+ 'navigate_and_interact'
63
+ ],
64
+ skills: [
65
+ 'browser-automation',
66
+ 'screenshot-capture',
67
+ 'web-interaction'
68
+ ],
69
+ resourceRequirements: {
70
+ memoryMB: 1024,
71
+ cpuUnits: 2
72
+ }
73
+ },
74
+ 'redis': {
75
+ name: 'redis',
76
+ displayName: 'Redis Database',
77
+ description: 'Redis key-value store operations',
78
+ containerImage: 'claude-flow-novice:mcp-redis',
79
+ tools: [
80
+ 'redis_get',
81
+ 'redis_set',
82
+ 'redis_keys'
83
+ ],
84
+ skills: [
85
+ 'redis-operations',
86
+ 'cache-management'
87
+ ],
88
+ resourceRequirements: {
89
+ memoryMB: 256,
90
+ cpuUnits: 1
91
+ }
92
+ },
93
+ 'postgres': {
94
+ name: 'postgres',
95
+ displayName: 'PostgreSQL Database',
96
+ description: 'PostgreSQL database operations',
97
+ containerImage: 'claude-flow-novice:mcp-postgres',
98
+ tools: [
99
+ 'postgres_query',
100
+ 'postgres_schema',
101
+ 'postgres_migrate'
102
+ ],
103
+ skills: [
104
+ 'database-design',
105
+ 'sql-operations'
106
+ ],
107
+ resourceRequirements: {
108
+ memoryMB: 512,
109
+ cpuUnits: 2
110
+ }
111
+ },
112
+ 'security-scanner': {
113
+ name: 'security-scanner',
114
+ displayName: 'Security Scanner',
115
+ description: 'Security vulnerability scanning and analysis',
116
+ containerImage: 'claude-flow-novice:mcp-security',
117
+ tools: [
118
+ 'security_scan',
119
+ 'vulnerability_check',
120
+ 'compliance_validate'
121
+ ],
122
+ skills: [
123
+ 'security-auditing',
124
+ 'vulnerability-scanning'
125
+ ],
126
+ resourceRequirements: {
127
+ memoryMB: 1536,
128
+ cpuUnits: 4
129
+ }
130
+ }
131
+ };
132
+ for (const [name, config] of Object.entries(defaultServers)){
133
+ this.mcpServers.set(name, config);
134
+ }
135
+ }
136
+ /**
137
+ * Determine which MCP servers an agent needs based on their skills
138
+ */ selectMCPServers(agentType, agentSkills = null) {
139
+ const agentConfig = this.agentWhitelist.get(agentType);
140
+ if (!agentConfig) {
141
+ throw new Error(`Unknown agent type: ${agentType}`);
142
+ }
143
+ // Use provided skills or fall back to agent config
144
+ const skills = agentSkills || agentConfig.skills;
145
+ // Determine required MCP servers based on skills
146
+ const requiredMCPServers = new Set();
147
+ const skillToMCPServerMap = this.getSkillToMCPServerMapping();
148
+ // Map skills to required MCP servers
149
+ for (const skill of skills){
150
+ if (skillToMCPServerMap.has(skill)) {
151
+ const servers = skillToMCPServerMap.get(skill);
152
+ servers.forEach((server)=>requiredMCPServers.add(server));
153
+ }
154
+ }
155
+ // Add explicitly allowed MCP servers from agent config
156
+ if (agentConfig.allowedMcpServers) {
157
+ agentConfig.allowedMcpServers.forEach((server)=>requiredMCPServers.add(server));
158
+ }
159
+ // Convert to array and sort by priority
160
+ const selectedServers = Array.from(requiredMCPServers).filter((server)=>this.mcpServers.has(server)).sort((a, b)=>{
161
+ const priorityA = this.mcpServers.get(a).priority || 999;
162
+ const priorityB = this.mcpServers.get(b).priority || 999;
163
+ return priorityA - priorityB;
164
+ });
165
+ return {
166
+ agentType,
167
+ agentSkills: skills,
168
+ selectedMCPServers,
169
+ serverDetails: selectedServers.map((server)=>this.mcpServers.get(server)),
170
+ totalMemoryRequired: selectedServers.reduce((sum, server)=>sum + (this.mcpServers.get(server).resourceRequirements?.memoryMB || 512), 0),
171
+ totalCPURequired: selectedServers.reduce((sum, server)=>sum + (this.mcpServers.get(server).resourceRequirements?.cpuUnits || 1), 0)
172
+ };
173
+ }
174
+ /**
175
+ * Get mapping from skills to required MCP servers
176
+ */ getSkillToMCPServerMapping() {
177
+ const skillMap = new Map();
178
+ // Build mapping from MCP server configurations
179
+ for (const [serverName, serverConfig] of this.mcpServers.entries()){
180
+ for (const skill of serverConfig.skills || []){
181
+ if (!skillMap.has(skill)) {
182
+ skillMap.set(skill, new Set());
183
+ }
184
+ skillMap.get(skill).add(serverName);
185
+ }
186
+ }
187
+ // Also add mappings from tool requirements
188
+ for (const [toolName, toolConfig] of this.skillRequirements.entries()){
189
+ for (const skill of toolConfig.requiredSkills || []){
190
+ // Find MCP servers that provide this tool
191
+ for (const [serverName, serverConfig] of this.mcpServers.entries()){
192
+ if (serverConfig.tools?.includes(toolName)) {
193
+ if (!skillMap.has(skill)) {
194
+ skillMap.set(skill, new Set());
195
+ }
196
+ skillMap.get(skill).add(serverName);
197
+ }
198
+ }
199
+ }
200
+ }
201
+ return skillMap;
202
+ }
203
+ /**
204
+ * Generate tokens for selected MCP servers
205
+ */ async generateMCPTokens(agentType, selectedServers, options = {}) {
206
+ const tokens = [];
207
+ for (const serverName of selectedServers){
208
+ try {
209
+ const serverConfig = this.mcpServers.get(serverName);
210
+ if (!serverConfig) {
211
+ console.warn(`[SkillMCPSelector] Server configuration not found: ${serverName}`);
212
+ continue;
213
+ }
214
+ // Generate server-specific token
215
+ const tokenData = await this.tokenManager.registerAgentToken(agentType, {
216
+ expiresIn: options.expiresIn || '24h',
217
+ description: `Token for ${serverConfig.displayName}`,
218
+ createdBy: 'skill-mcp-selector',
219
+ mcpServer: serverName
220
+ });
221
+ tokens.push({
222
+ serverName,
223
+ displayName: serverConfig.displayName,
224
+ token: tokenData.token,
225
+ expiresAt: tokenData.expiresAt,
226
+ containerImage: serverConfig.containerImage,
227
+ connectionInfo: this.generateConnectionInfo(serverName, serverConfig, tokenData.token)
228
+ });
229
+ console.log(`[SkillMCPSelector] Generated token for ${agentType} → ${serverName}`);
230
+ } catch (error) {
231
+ console.error(`[SkillMCPSelector] Failed to generate token for ${serverName}:`, error);
232
+ }
233
+ }
234
+ return tokens;
235
+ }
236
+ /**
237
+ * Generate connection information for MCP server
238
+ */ generateConnectionInfo(serverName, serverConfig, token) {
239
+ const baseInfo = {
240
+ serverName,
241
+ token,
242
+ authentication: {
243
+ type: 'token-based',
244
+ header: 'x-agent-token',
245
+ agentTypeHeader: 'x-agent-type'
246
+ }
247
+ };
248
+ // Add server-specific connection details
249
+ if (serverConfig.connectionType === 'docker') {
250
+ return {
251
+ ...baseInfo,
252
+ type: 'docker-container',
253
+ containerName: `mcp-${serverName}`,
254
+ containerImage: serverConfig.containerImage,
255
+ dockerArgs: [
256
+ 'run',
257
+ '--rm',
258
+ '--init',
259
+ '--name',
260
+ `mcp-${serverName}`,
261
+ '--memory',
262
+ `${serverConfig.resourceRequirements?.memoryMB || 512}m`,
263
+ '--cpus',
264
+ `${serverConfig.resourceRequirements?.cpuUnits || 1}`,
265
+ '-e',
266
+ `MCP_SERVER=${serverName}`,
267
+ '-e',
268
+ `MCP_AUTH_REQUIRED=true`,
269
+ '-e',
270
+ `MCP_REDIS_URL=${process.env.MCP_REDIS_URL || 'redis://localhost:6379'}`,
271
+ serverConfig.containerImage,
272
+ 'node',
273
+ `/app/mcp-${serverName}-server.js`
274
+ ]
275
+ };
276
+ } else {
277
+ return {
278
+ ...baseInfo,
279
+ type: 'http-endpoint',
280
+ url: serverConfig.url || `http://localhost:${3000 + this.mcpServers.size}`,
281
+ headers: {
282
+ 'Content-Type': 'application/json',
283
+ 'x-agent-token': token,
284
+ 'x-agent-type': 'dynamic'
285
+ }
286
+ };
287
+ }
288
+ }
289
+ /**
290
+ * Get complete MCP configuration for an agent
291
+ */ async getAgentMCPConfiguration(agentType, agentSkills = null, options = {}) {
292
+ try {
293
+ // Select required MCP servers
294
+ const selection = this.selectMCPServers(agentType, agentSkills);
295
+ // Generate tokens for selected servers
296
+ const tokens = await this.generateMCPTokens(agentType, selection.selectedMCPServers, options);
297
+ return {
298
+ agentType,
299
+ agentSkills: selection.agentSkills,
300
+ mcpConfiguration: {
301
+ mcpServers: tokens.reduce((config, tokenInfo)=>{
302
+ config[tokenInfo.serverName] = {
303
+ command: 'docker',
304
+ args: tokenInfo.connectionInfo.dockerArgs,
305
+ env: {
306
+ 'MCP_SERVER': tokenInfo.serverName,
307
+ 'MCP_AUTH_REQUIRED': 'true',
308
+ 'AGENT_TOKEN': tokenInfo.token
309
+ }
310
+ };
311
+ return config;
312
+ }, {})
313
+ },
314
+ selection,
315
+ tokens,
316
+ resourceSummary: {
317
+ totalMemoryMB: selection.totalMemoryRequired,
318
+ totalCPUUnits: selection.totalCPUUnits,
319
+ serverCount: selection.selectedMCPServers.length
320
+ }
321
+ };
322
+ } catch (error) {
323
+ console.error(`[SkillMCPSelector] Failed to get MCP configuration for ${agentType}:`, error);
324
+ throw error;
325
+ }
326
+ }
327
+ /**
328
+ * Generate Docker Compose configuration for agent with MCP servers
329
+ */ async generateDockerComposeConfiguration(agentType, agentSkills = null, options = {}) {
330
+ const config = await this.getAgentMCPConfiguration(agentType, agentSkills, options);
331
+ const dockerCompose = {
332
+ version: '3.8',
333
+ services: {},
334
+ networks: {
335
+ 'mcp-network': {
336
+ driver: 'bridge'
337
+ }
338
+ }
339
+ };
340
+ // Add agent service
341
+ dockerCompose.services[`${agentType}-agent`] = {
342
+ image: 'claude-flow-novice:agent-container',
343
+ container_name: `agent-${agentType}-${Date.now()}`,
344
+ networks: [
345
+ 'mcp-network'
346
+ ],
347
+ environment: {
348
+ 'AGENT_TYPE': agentType,
349
+ 'AGENT_MODE': 'containerized',
350
+ 'MCP_AUTH_ENABLED': 'true',
351
+ 'REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379'
352
+ },
353
+ volumes: [
354
+ '${PWD}/.claude:/app/.claude:ro',
355
+ '${PWD}/screenshots:/app/screenshots'
356
+ ],
357
+ mem_limit: `${config.resourceSummary.totalMemoryMB + 512}m`,
358
+ depends_on: config.selection.selectedMCPServers.map((server)=>`mcp-${server}`).join(' ')
359
+ };
360
+ // Add MCP server services
361
+ for (const tokenInfo of config.tokens){
362
+ const serverName = `mcp-${tokenInfo.serverName}`;
363
+ const serverConfig = this.mcpServers.get(tokenInfo.serverName);
364
+ dockerCompose.services[serverName] = {
365
+ image: tokenInfo.containerImage,
366
+ container_name: `${serverName}-${Date.now()}`,
367
+ networks: [
368
+ 'mcp-network'
369
+ ],
370
+ environment: {
371
+ 'MCP_SERVER': tokenInfo.serverName,
372
+ 'MCP_AUTH_REQUIRED': 'true',
373
+ 'MCP_REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379',
374
+ 'AGENT_TOKEN': tokenInfo.token
375
+ },
376
+ volumes: [
377
+ '${PWD}/screenshots:/app/screenshots'
378
+ ],
379
+ mem_limit: `${serverConfig.resourceRequirements?.memoryMB || 512}m`,
380
+ cpus: `${(serverConfig.resourceRequirements?.cpuUnits || 1) / 4}`
381
+ };
382
+ }
383
+ // Add Redis service if not present
384
+ if (!dockerCompose.services.redis) {
385
+ dockerCompose.services.redis = {
386
+ image: 'redis:7-alpine',
387
+ container_name: 'mcp-redis',
388
+ networks: [
389
+ 'mcp-network'
390
+ ],
391
+ volumes: [
392
+ 'redis-data:/data'
393
+ ],
394
+ mem_limit: '256m'
395
+ };
396
+ dockerCompose.volumes = {
397
+ 'redis-data': {}
398
+ };
399
+ }
400
+ return dockerCompose;
401
+ }
402
+ /**
403
+ * Get statistics about skill-MCP mappings
404
+ */ getStatistics() {
405
+ const skillMap = this.getSkillToMCPServerMapping();
406
+ return {
407
+ totalAgents: this.agentWhitelist.size,
408
+ totalMCPServers: this.mcpServers.size,
409
+ totalSkills: skillMap.size,
410
+ agentTypes: Array.from(this.agentWhitelist.keys()),
411
+ mcpServerNames: Array.from(this.mcpServers.keys()),
412
+ skillCoverage: Array.from(skillMap.entries()).map(([skill, servers])=>({
413
+ skill,
414
+ requiredServers: Array.from(servers),
415
+ serverCount: servers.size
416
+ }))
417
+ };
418
+ }
419
+ /**
420
+ * Validate agent-MCP configuration
421
+ */ validateConfiguration(agentType, mcpConfiguration) {
422
+ const agentConfig = this.agentWhitelist.get(agentType);
423
+ if (!agentConfig) {
424
+ return {
425
+ valid: false,
426
+ errors: [
427
+ `Unknown agent type: ${agentType}`
428
+ ]
429
+ };
430
+ }
431
+ const errors = [];
432
+ const warnings = [];
433
+ // Check required MCP servers
434
+ const requiredServers = agentConfig.allowedMcpServers || [];
435
+ const configuredServers = Object.keys(mcpConfiguration.mcpServers || {});
436
+ for (const server of requiredServers){
437
+ if (!configuredServers.includes(server)) {
438
+ errors.push(`Required MCP server missing: ${server}`);
439
+ }
440
+ }
441
+ // Check for unauthorized servers
442
+ for (const server of configuredServers){
443
+ if (!requiredServers.includes(server)) {
444
+ warnings.push(`Potentially unauthorized MCP server: ${server}`);
445
+ }
446
+ }
447
+ return {
448
+ valid: errors.length === 0,
449
+ errors,
450
+ warnings
451
+ };
452
+ }
453
+ async shutdown() {
454
+ await this.tokenManager.shutdown();
455
+ }
456
+ };
457
+ module.exports = SkillMCPSelector;
458
+
459
+ //# sourceMappingURL=skill-mcp-selector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/agent/skill-mcp-selector.js"],"sourcesContent":["/**\r\n * Skill-based MCP Selection System\r\n * Automatically selects MCP servers based on agent skills and requirements\r\n */\r\n\r\nconst fs = require('fs').promises;\r\nconst path = require('path');\r\nconst AgentTokenManager = require('../cli/agent-token-manager.js');\r\n\r\nclass SkillMCPSelector {\r\n constructor(options = {}) {\r\n this.tokenManager = new AgentTokenManager(options);\r\n this.agentConfigPath = options.agentConfigPath || './config/agent-whitelist.json';\r\n this.skillConfigPath = options.skillConfigPath || './config/skill-requirements.json';\r\n this.mcpServersPath = options.mcpServersPath || './config/mcp-servers.json';\r\n\r\n this.agentWhitelist = new Map();\r\n this.skillRequirements = new Map();\r\n this.mcpServers = new Map();\r\n }\r\n\r\n async initialize() {\r\n await this.tokenManager.initialize();\r\n await this.loadConfigurations();\r\n console.log('[SkillMCPSelector] Initialized successfully');\r\n }\r\n\r\n async loadConfigurations() {\r\n // Load agent whitelist\r\n const agentConfig = await this.loadJson(this.agentConfigPath);\r\n this.agentWhitelist.clear();\r\n for (const agent of agentConfig.agents) {\r\n this.agentWhitelist.set(agent.type, agent);\r\n }\r\n\r\n // Load skill requirements\r\n const skillConfig = await this.loadJson(this.skillConfigPath);\r\n this.skillRequirements.clear();\r\n for (const [tool, requirements] of Object.entries(skillConfig.tools)) {\r\n this.skillRequirements.set(tool, requirements);\r\n }\r\n\r\n // Load MCP server configurations\r\n try {\r\n const mcpConfig = await this.loadJson(this.mcpServersPath);\r\n for (const [name, config] of Object.entries(mcpConfig.servers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n } catch (error) {\r\n console.warn('[SkillMCPSelector] MCP servers config not found, using defaults');\r\n this.initializeDefaultMCPServers();\r\n }\r\n }\r\n\r\n async loadJson(filePath) {\r\n const resolvedPath = path.resolve(filePath);\r\n const content = await fs.readFile(resolvedPath, 'utf8');\r\n return JSON.parse(content);\r\n }\r\n\r\n initializeDefaultMCPServers() {\r\n // Default MCP server configurations\r\n const defaultServers = {\r\n 'playwright': {\r\n name: 'playwright',\r\n displayName: 'Playwright Browser Automation',\r\n description: 'Browser automation and screenshot capabilities',\r\n containerImage: 'claude-flow-novice:mcp-playwright',\r\n tools: ['take_screenshot', 'search_google', 'navigate_and_interact'],\r\n skills: ['browser-automation', 'screenshot-capture', 'web-interaction'],\r\n resourceRequirements: {\r\n memoryMB: 1024,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'redis': {\r\n name: 'redis',\r\n displayName: 'Redis Database',\r\n description: 'Redis key-value store operations',\r\n containerImage: 'claude-flow-novice:mcp-redis',\r\n tools: ['redis_get', 'redis_set', 'redis_keys'],\r\n skills: ['redis-operations', 'cache-management'],\r\n resourceRequirements: {\r\n memoryMB: 256,\r\n cpuUnits: 1\r\n }\r\n },\r\n 'postgres': {\r\n name: 'postgres',\r\n displayName: 'PostgreSQL Database',\r\n description: 'PostgreSQL database operations',\r\n containerImage: 'claude-flow-novice:mcp-postgres',\r\n tools: ['postgres_query', 'postgres_schema', 'postgres_migrate'],\r\n skills: ['database-design', 'sql-operations'],\r\n resourceRequirements: {\r\n memoryMB: 512,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'security-scanner': {\r\n name: 'security-scanner',\r\n displayName: 'Security Scanner',\r\n description: 'Security vulnerability scanning and analysis',\r\n containerImage: 'claude-flow-novice:mcp-security',\r\n tools: ['security_scan', 'vulnerability_check', 'compliance_validate'],\r\n skills: ['security-auditing', 'vulnerability-scanning'],\r\n resourceRequirements: {\r\n memoryMB: 1536,\r\n cpuUnits: 4\r\n }\r\n }\r\n };\r\n\r\n for (const [name, config] of Object.entries(defaultServers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n }\r\n\r\n /**\r\n * Determine which MCP servers an agent needs based on their skills\r\n */\r\n selectMCPServers(agentType, agentSkills = null) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n throw new Error(`Unknown agent type: ${agentType}`);\r\n }\r\n\r\n // Use provided skills or fall back to agent config\r\n const skills = agentSkills || agentConfig.skills;\r\n\r\n // Determine required MCP servers based on skills\r\n const requiredMCPServers = new Set();\r\n const skillToMCPServerMap = this.getSkillToMCPServerMapping();\r\n\r\n // Map skills to required MCP servers\r\n for (const skill of skills) {\r\n if (skillToMCPServerMap.has(skill)) {\r\n const servers = skillToMCPServerMap.get(skill);\r\n servers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n }\r\n\r\n // Add explicitly allowed MCP servers from agent config\r\n if (agentConfig.allowedMcpServers) {\r\n agentConfig.allowedMcpServers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n\r\n // Convert to array and sort by priority\r\n const selectedServers = Array.from(requiredMCPServers)\r\n .filter(server => this.mcpServers.has(server))\r\n .sort((a, b) => {\r\n const priorityA = this.mcpServers.get(a).priority || 999;\r\n const priorityB = this.mcpServers.get(b).priority || 999;\r\n return priorityA - priorityB;\r\n });\r\n\r\n return {\r\n agentType,\r\n agentSkills: skills,\r\n selectedMCPServers,\r\n serverDetails: selectedServers.map(server => this.mcpServers.get(server)),\r\n totalMemoryRequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.memoryMB || 512), 0),\r\n totalCPURequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.cpuUnits || 1), 0)\r\n };\r\n }\r\n\r\n /**\r\n * Get mapping from skills to required MCP servers\r\n */\r\n getSkillToMCPServerMapping() {\r\n const skillMap = new Map();\r\n\r\n // Build mapping from MCP server configurations\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n for (const skill of serverConfig.skills || []) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n\r\n // Also add mappings from tool requirements\r\n for (const [toolName, toolConfig] of this.skillRequirements.entries()) {\r\n for (const skill of toolConfig.requiredSkills || []) {\r\n // Find MCP servers that provide this tool\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n if (serverConfig.tools?.includes(toolName)) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n }\r\n }\r\n\r\n return skillMap;\r\n }\r\n\r\n /**\r\n * Generate tokens for selected MCP servers\r\n */\r\n async generateMCPTokens(agentType, selectedServers, options = {}) {\r\n const tokens = [];\r\n\r\n for (const serverName of selectedServers) {\r\n try {\r\n const serverConfig = this.mcpServers.get(serverName);\r\n if (!serverConfig) {\r\n console.warn(`[SkillMCPSelector] Server configuration not found: ${serverName}`);\r\n continue;\r\n }\r\n\r\n // Generate server-specific token\r\n const tokenData = await this.tokenManager.registerAgentToken(agentType, {\r\n expiresIn: options.expiresIn || '24h',\r\n description: `Token for ${serverConfig.displayName}`,\r\n createdBy: 'skill-mcp-selector',\r\n mcpServer: serverName\r\n });\r\n\r\n tokens.push({\r\n serverName,\r\n displayName: serverConfig.displayName,\r\n token: tokenData.token,\r\n expiresAt: tokenData.expiresAt,\r\n containerImage: serverConfig.containerImage,\r\n connectionInfo: this.generateConnectionInfo(serverName, serverConfig, tokenData.token)\r\n });\r\n\r\n console.log(`[SkillMCPSelector] Generated token for ${agentType} → ${serverName}`);\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to generate token for ${serverName}:`, error);\r\n }\r\n }\r\n\r\n return tokens;\r\n }\r\n\r\n /**\r\n * Generate connection information for MCP server\r\n */\r\n generateConnectionInfo(serverName, serverConfig, token) {\r\n const baseInfo = {\r\n serverName,\r\n token,\r\n authentication: {\r\n type: 'token-based',\r\n header: 'x-agent-token',\r\n agentTypeHeader: 'x-agent-type'\r\n }\r\n };\r\n\r\n // Add server-specific connection details\r\n if (serverConfig.connectionType === 'docker') {\r\n return {\r\n ...baseInfo,\r\n type: 'docker-container',\r\n containerName: `mcp-${serverName}`,\r\n containerImage: serverConfig.containerImage,\r\n dockerArgs: [\r\n 'run', '--rm', '--init',\r\n '--name', `mcp-${serverName}`,\r\n '--memory', `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n '--cpus', `${serverConfig.resourceRequirements?.cpuUnits || 1}`,\r\n '-e', `MCP_SERVER=${serverName}`,\r\n '-e', `MCP_AUTH_REQUIRED=true`,\r\n '-e', `MCP_REDIS_URL=${process.env.MCP_REDIS_URL || 'redis://localhost:6379'}`,\r\n serverConfig.containerImage,\r\n 'node', `/app/mcp-${serverName}-server.js`\r\n ]\r\n };\r\n } else {\r\n return {\r\n ...baseInfo,\r\n type: 'http-endpoint',\r\n url: serverConfig.url || `http://localhost:${3000 + this.mcpServers.size}`,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'x-agent-token': token,\r\n 'x-agent-type': 'dynamic'\r\n }\r\n };\r\n }\r\n }\r\n\r\n /**\r\n * Get complete MCP configuration for an agent\r\n */\r\n async getAgentMCPConfiguration(agentType, agentSkills = null, options = {}) {\r\n try {\r\n // Select required MCP servers\r\n const selection = this.selectMCPServers(agentType, agentSkills);\r\n\r\n // Generate tokens for selected servers\r\n const tokens = await this.generateMCPTokens(\r\n agentType,\r\n selection.selectedMCPServers,\r\n options\r\n );\r\n\r\n return {\r\n agentType,\r\n agentSkills: selection.agentSkills,\r\n mcpConfiguration: {\r\n mcpServers: tokens.reduce((config, tokenInfo) => {\r\n config[tokenInfo.serverName] = {\r\n command: 'docker',\r\n args: tokenInfo.connectionInfo.dockerArgs,\r\n env: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n }\r\n };\r\n return config;\r\n }, {})\r\n },\r\n selection,\r\n tokens,\r\n resourceSummary: {\r\n totalMemoryMB: selection.totalMemoryRequired,\r\n totalCPUUnits: selection.totalCPUUnits,\r\n serverCount: selection.selectedMCPServers.length\r\n }\r\n };\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to get MCP configuration for ${agentType}:`, error);\r\n throw error;\r\n }\r\n }\r\n\r\n /**\r\n * Generate Docker Compose configuration for agent with MCP servers\r\n */\r\n async generateDockerComposeConfiguration(agentType, agentSkills = null, options = {}) {\r\n const config = await this.getAgentMCPConfiguration(agentType, agentSkills, options);\r\n\r\n const dockerCompose = {\r\n version: '3.8',\r\n services: {},\r\n networks: {\r\n 'mcp-network': {\r\n driver: 'bridge'\r\n }\r\n }\r\n };\r\n\r\n // Add agent service\r\n dockerCompose.services[`${agentType}-agent`] = {\r\n image: 'claude-flow-novice:agent-container',\r\n container_name: `agent-${agentType}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'AGENT_TYPE': agentType,\r\n 'AGENT_MODE': 'containerized',\r\n 'MCP_AUTH_ENABLED': 'true',\r\n 'REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379'\r\n },\r\n volumes: [\r\n '${PWD}/.claude:/app/.claude:ro',\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${config.resourceSummary.totalMemoryMB + 512}m`,\r\n depends_on: config.selection.selectedMCPServers.map(server => `mcp-${server}`).join(' ')\r\n };\r\n\r\n // Add MCP server services\r\n for (const tokenInfo of config.tokens) {\r\n const serverName = `mcp-${tokenInfo.serverName}`;\r\n const serverConfig = this.mcpServers.get(tokenInfo.serverName);\r\n\r\n dockerCompose.services[serverName] = {\r\n image: tokenInfo.containerImage,\r\n container_name: `${serverName}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'MCP_REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n },\r\n volumes: [\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n cpus: `${(serverConfig.resourceRequirements?.cpuUnits || 1) / 4}`\r\n };\r\n }\r\n\r\n // Add Redis service if not present\r\n if (!dockerCompose.services.redis) {\r\n dockerCompose.services.redis = {\r\n image: 'redis:7-alpine',\r\n container_name: 'mcp-redis',\r\n networks: ['mcp-network'],\r\n volumes: ['redis-data:/data'],\r\n mem_limit: '256m'\r\n };\r\n dockerCompose.volumes = {\r\n 'redis-data': {}\r\n };\r\n }\r\n\r\n return dockerCompose;\r\n }\r\n\r\n /**\r\n * Get statistics about skill-MCP mappings\r\n */\r\n getStatistics() {\r\n const skillMap = this.getSkillToMCPServerMapping();\r\n\r\n return {\r\n totalAgents: this.agentWhitelist.size,\r\n totalMCPServers: this.mcpServers.size,\r\n totalSkills: skillMap.size,\r\n agentTypes: Array.from(this.agentWhitelist.keys()),\r\n mcpServerNames: Array.from(this.mcpServers.keys()),\r\n skillCoverage: Array.from(skillMap.entries()).map(([skill, servers]) => ({\r\n skill,\r\n requiredServers: Array.from(servers),\r\n serverCount: servers.size\r\n }))\r\n };\r\n }\r\n\r\n /**\r\n * Validate agent-MCP configuration\r\n */\r\n validateConfiguration(agentType, mcpConfiguration) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n return { valid: false, errors: [`Unknown agent type: ${agentType}`] };\r\n }\r\n\r\n const errors = [];\r\n const warnings = [];\r\n\r\n // Check required MCP servers\r\n const requiredServers = agentConfig.allowedMcpServers || [];\r\n const configuredServers = Object.keys(mcpConfiguration.mcpServers || {});\r\n\r\n for (const server of requiredServers) {\r\n if (!configuredServers.includes(server)) {\r\n errors.push(`Required MCP server missing: ${server}`);\r\n }\r\n }\r\n\r\n // Check for unauthorized servers\r\n for (const server of configuredServers) {\r\n if (!requiredServers.includes(server)) {\r\n warnings.push(`Potentially unauthorized MCP server: ${server}`);\r\n }\r\n }\r\n\r\n return {\r\n valid: errors.length === 0,\r\n errors,\r\n warnings\r\n };\r\n }\r\n\r\n async shutdown() {\r\n await this.tokenManager.shutdown();\r\n }\r\n}\r\n\r\nmodule.exports = SkillMCPSelector;"],"names":["fs","require","promises","path","AgentTokenManager","SkillMCPSelector","options","tokenManager","agentConfigPath","skillConfigPath","mcpServersPath","agentWhitelist","Map","skillRequirements","mcpServers","initialize","loadConfigurations","console","log","agentConfig","loadJson","clear","agent","agents","set","type","skillConfig","tool","requirements","Object","entries","tools","mcpConfig","name","config","servers","error","warn","initializeDefaultMCPServers","filePath","resolvedPath","resolve","content","readFile","JSON","parse","defaultServers","displayName","description","containerImage","skills","resourceRequirements","memoryMB","cpuUnits","selectMCPServers","agentType","agentSkills","get","Error","requiredMCPServers","Set","skillToMCPServerMap","getSkillToMCPServerMapping","skill","has","forEach","server","add","allowedMcpServers","selectedServers","Array","from","filter","sort","a","b","priorityA","priority","priorityB","selectedMCPServers","serverDetails","map","totalMemoryRequired","reduce","sum","totalCPURequired","skillMap","serverName","serverConfig","toolName","toolConfig","requiredSkills","includes","generateMCPTokens","tokens","tokenData","registerAgentToken","expiresIn","createdBy","mcpServer","push","token","expiresAt","connectionInfo","generateConnectionInfo","baseInfo","authentication","header","agentTypeHeader","connectionType","containerName","dockerArgs","process","env","MCP_REDIS_URL","url","size","headers","getAgentMCPConfiguration","selection","mcpConfiguration","tokenInfo","command","args","resourceSummary","totalMemoryMB","totalCPUUnits","serverCount","length","generateDockerComposeConfiguration","dockerCompose","version","services","networks","driver","image","container_name","Date","now","environment","volumes","mem_limit","depends_on","join","cpus","redis","getStatistics","totalAgents","totalMCPServers","totalSkills","agentTypes","keys","mcpServerNames","skillCoverage","requiredServers","validateConfiguration","valid","errors","warnings","configuredServers","shutdown","module","exports"],"mappings":"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"}