@juspay/neurolink 7.13.0 → 7.14.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/README.md +89 -25
- package/dist/agent/directTools.d.ts +3 -3
- package/dist/agent/directTools.js +1 -1
- package/dist/cli/commands/mcp.js +67 -207
- package/dist/cli/factories/commandFactory.js +7 -1
- package/dist/cli/utils/interactiveSetup.js +1 -1
- package/dist/config/conversationMemoryConfig.js +2 -1
- package/dist/context/ContextManager.js +15 -4
- package/dist/context/config.js +5 -1
- package/dist/context/utils.js +1 -1
- package/dist/core/baseProvider.d.ts +11 -30
- package/dist/core/baseProvider.js +268 -42
- package/dist/core/conversationMemoryManager.js +3 -2
- package/dist/core/dynamicModels.d.ts +14 -14
- package/dist/core/dynamicModels.js +1 -1
- package/dist/core/evaluation.js +1 -1
- package/dist/core/factory.js +1 -1
- package/dist/factories/providerFactory.js +5 -11
- package/dist/factories/providerRegistry.js +2 -2
- package/dist/index.d.ts +5 -4
- package/dist/index.js +1 -1
- package/dist/lib/agent/directTools.js +1 -1
- package/dist/lib/config/conversationMemoryConfig.js +2 -1
- package/dist/lib/context/ContextManager.js +15 -4
- package/dist/lib/context/config.js +5 -1
- package/dist/lib/context/utils.js +1 -1
- package/dist/lib/core/baseProvider.d.ts +11 -30
- package/dist/lib/core/baseProvider.js +268 -42
- package/dist/lib/core/conversationMemoryManager.js +3 -2
- package/dist/lib/core/dynamicModels.js +1 -1
- package/dist/lib/core/evaluation.js +1 -1
- package/dist/lib/core/factory.js +1 -1
- package/dist/lib/factories/providerFactory.js +5 -11
- package/dist/lib/factories/providerRegistry.js +2 -2
- package/dist/lib/index.d.ts +5 -4
- package/dist/lib/index.js +1 -1
- package/dist/lib/mcp/externalServerManager.d.ts +148 -0
- package/dist/lib/mcp/externalServerManager.js +1038 -0
- package/dist/lib/mcp/mcpCircuitBreaker.d.ts +184 -0
- package/dist/lib/mcp/mcpCircuitBreaker.js +338 -0
- package/dist/lib/mcp/mcpClientFactory.d.ts +105 -0
- package/dist/lib/mcp/mcpClientFactory.js +421 -0
- package/dist/lib/mcp/toolDiscoveryService.d.ts +193 -0
- package/dist/lib/mcp/toolDiscoveryService.js +646 -0
- package/dist/lib/mcp/toolRegistry.d.ts +15 -11
- package/dist/lib/mcp/toolRegistry.js +118 -55
- package/dist/lib/models/modelResolver.js +1 -1
- package/dist/lib/neurolink.d.ts +139 -43
- package/dist/lib/neurolink.js +604 -174
- package/dist/lib/providers/googleVertex.d.ts +7 -1
- package/dist/lib/providers/googleVertex.js +34 -7
- package/dist/lib/providers/huggingFace.js +1 -1
- package/dist/lib/providers/mistral.js +3 -3
- package/dist/lib/providers/ollama.js +1 -1
- package/dist/lib/providers/openAI.d.ts +3 -2
- package/dist/lib/providers/openAI.js +2 -2
- package/dist/lib/providers/openaiCompatible.d.ts +1 -1
- package/dist/lib/providers/openaiCompatible.js +2 -2
- package/dist/lib/providers/sagemaker/config.js +1 -1
- package/dist/lib/sdk/toolRegistration.d.ts +4 -13
- package/dist/lib/sdk/toolRegistration.js +19 -66
- package/dist/lib/types/cli.d.ts +0 -1
- package/dist/lib/types/cli.js +0 -1
- package/dist/lib/types/common.d.ts +1 -2
- package/dist/lib/types/common.js +0 -1
- package/dist/lib/types/contextTypes.d.ts +1 -1
- package/dist/lib/types/contextTypes.js +3 -3
- package/dist/lib/types/externalMcp.d.ts +288 -0
- package/dist/lib/types/externalMcp.js +7 -0
- package/dist/lib/types/generateTypes.d.ts +0 -1
- package/dist/lib/types/index.d.ts +2 -2
- package/dist/lib/types/index.js +0 -1
- package/dist/lib/types/mcpTypes.d.ts +53 -99
- package/dist/lib/types/providers.d.ts +0 -1
- package/dist/lib/types/providers.js +0 -1
- package/dist/lib/types/tools.d.ts +2 -2
- package/dist/lib/types/tools.js +2 -2
- package/dist/lib/utils/factoryProcessing.js +1 -1
- package/dist/lib/utils/mcpDefaults.d.ts +54 -0
- package/dist/lib/utils/mcpDefaults.js +125 -0
- package/dist/lib/utils/providerConfig.d.ts +1 -1
- package/dist/lib/utils/providerConfig.js +2 -2
- package/dist/lib/utils/providerHealth.js +6 -6
- package/dist/mcp/externalServerManager.d.ts +148 -0
- package/dist/mcp/externalServerManager.js +1038 -0
- package/dist/mcp/mcpCircuitBreaker.d.ts +184 -0
- package/dist/mcp/mcpCircuitBreaker.js +338 -0
- package/dist/mcp/mcpClientFactory.d.ts +105 -0
- package/dist/mcp/mcpClientFactory.js +421 -0
- package/dist/mcp/toolDiscoveryService.d.ts +193 -0
- package/dist/mcp/toolDiscoveryService.js +646 -0
- package/dist/mcp/toolRegistry.d.ts +15 -11
- package/dist/mcp/toolRegistry.js +118 -55
- package/dist/models/modelResolver.js +1 -1
- package/dist/neurolink.d.ts +139 -43
- package/dist/neurolink.js +604 -174
- package/dist/providers/googleVertex.d.ts +7 -1
- package/dist/providers/googleVertex.js +34 -7
- package/dist/providers/huggingFace.js +1 -1
- package/dist/providers/mistral.js +3 -3
- package/dist/providers/ollama.js +1 -1
- package/dist/providers/openAI.d.ts +3 -2
- package/dist/providers/openAI.js +2 -2
- package/dist/providers/openaiCompatible.d.ts +1 -1
- package/dist/providers/openaiCompatible.js +2 -2
- package/dist/providers/sagemaker/config.js +1 -1
- package/dist/sdk/toolRegistration.d.ts +4 -13
- package/dist/sdk/toolRegistration.js +19 -66
- package/dist/types/cli.d.ts +0 -1
- package/dist/types/cli.js +0 -1
- package/dist/types/common.d.ts +1 -2
- package/dist/types/common.js +0 -1
- package/dist/types/contextTypes.d.ts +1 -1
- package/dist/types/contextTypes.js +3 -3
- package/dist/types/externalMcp.d.ts +288 -0
- package/dist/types/externalMcp.js +7 -0
- package/dist/types/generateTypes.d.ts +0 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.js +0 -1
- package/dist/types/mcpTypes.d.ts +53 -99
- package/dist/types/providers.d.ts +0 -1
- package/dist/types/providers.js +0 -1
- package/dist/types/tools.d.ts +2 -2
- package/dist/types/tools.js +2 -2
- package/dist/utils/factoryProcessing.js +1 -1
- package/dist/utils/mcpDefaults.d.ts +54 -0
- package/dist/utils/mcpDefaults.js +125 -0
- package/dist/utils/providerConfig.d.ts +1 -1
- package/dist/utils/providerConfig.js +2 -2
- package/dist/utils/providerHealth.js +6 -6
- package/package.json +1 -1
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Smart Defaults for MCPServerInfo Creation
|
|
3
|
+
* Eliminates boilerplate manual object creation
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Smart category detection based on context
|
|
7
|
+
*/
|
|
8
|
+
export function detectCategory(context) {
|
|
9
|
+
// If category is already provided, validate and use it
|
|
10
|
+
if (context.existingCategory) {
|
|
11
|
+
const validCategories = [
|
|
12
|
+
"external",
|
|
13
|
+
"in-memory",
|
|
14
|
+
"built-in",
|
|
15
|
+
"user-defined",
|
|
16
|
+
];
|
|
17
|
+
if (validCategories.includes(context.existingCategory)) {
|
|
18
|
+
return context.existingCategory;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
// Smart detection based on context
|
|
22
|
+
if (context.isCustomTool) {
|
|
23
|
+
return "user-defined";
|
|
24
|
+
}
|
|
25
|
+
if (context.isBuiltIn) {
|
|
26
|
+
return "built-in";
|
|
27
|
+
}
|
|
28
|
+
if (context.isExternal) {
|
|
29
|
+
return "external";
|
|
30
|
+
}
|
|
31
|
+
if (context.serverId?.startsWith("custom-tool-")) {
|
|
32
|
+
return "user-defined";
|
|
33
|
+
}
|
|
34
|
+
if (context.serverId?.includes("external")) {
|
|
35
|
+
return "external";
|
|
36
|
+
}
|
|
37
|
+
if (context.serverId === "direct") {
|
|
38
|
+
return "built-in";
|
|
39
|
+
}
|
|
40
|
+
// Default to in-memory for most cases
|
|
41
|
+
return "in-memory";
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Generate smart description based on name and category
|
|
45
|
+
*/
|
|
46
|
+
function generateDescription(name, category) {
|
|
47
|
+
// Generate descriptions based on category for better context
|
|
48
|
+
switch (category) {
|
|
49
|
+
case "external":
|
|
50
|
+
return `External MCP server: ${name}`;
|
|
51
|
+
case "built-in":
|
|
52
|
+
return `Built-in tool server: ${name}`;
|
|
53
|
+
case "custom":
|
|
54
|
+
case "user-defined":
|
|
55
|
+
return `Custom tool server: ${name}`;
|
|
56
|
+
case "in-memory":
|
|
57
|
+
return `In-memory MCP server: ${name}`;
|
|
58
|
+
default:
|
|
59
|
+
return name;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Create MCPServerInfo with smart defaults
|
|
64
|
+
* Eliminates manual boilerplate object creation
|
|
65
|
+
*/
|
|
66
|
+
export function createMCPServerInfo(options) {
|
|
67
|
+
const id = options.id || `server-${options.name}`;
|
|
68
|
+
const category = options.category ||
|
|
69
|
+
detectCategory({
|
|
70
|
+
isCustomTool: options.isCustomTool,
|
|
71
|
+
isExternal: options.isExternal,
|
|
72
|
+
isBuiltIn: options.isBuiltIn,
|
|
73
|
+
serverId: id,
|
|
74
|
+
});
|
|
75
|
+
const tools = options.tools || (options.tool ? [options.tool] : []);
|
|
76
|
+
return {
|
|
77
|
+
id,
|
|
78
|
+
name: options.name,
|
|
79
|
+
transport: options.transport || "stdio",
|
|
80
|
+
status: options.status || "connected",
|
|
81
|
+
tools,
|
|
82
|
+
description: options.description || generateDescription(options.name, category),
|
|
83
|
+
...(options.command && { command: options.command }),
|
|
84
|
+
...(options.args && { args: options.args }),
|
|
85
|
+
...(options.env && { env: options.env }),
|
|
86
|
+
metadata: {
|
|
87
|
+
category: category,
|
|
88
|
+
toolCount: tools.length,
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Create MCPServerInfo for custom tool registration
|
|
94
|
+
* Specialized version with smart defaults for registerTool usage
|
|
95
|
+
*/
|
|
96
|
+
export function createCustomToolServerInfo(toolName, tool) {
|
|
97
|
+
return createMCPServerInfo({
|
|
98
|
+
id: `custom-tool-${toolName}`,
|
|
99
|
+
name: toolName,
|
|
100
|
+
tool: {
|
|
101
|
+
name: toolName,
|
|
102
|
+
description: tool.description || toolName,
|
|
103
|
+
inputSchema: tool.inputSchema || {},
|
|
104
|
+
execute: tool.execute,
|
|
105
|
+
},
|
|
106
|
+
isCustomTool: true,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Create MCPServerInfo for external servers
|
|
111
|
+
* Specialized version with smart defaults for external server usage
|
|
112
|
+
*/
|
|
113
|
+
export function createExternalServerInfo(options) {
|
|
114
|
+
return createMCPServerInfo({
|
|
115
|
+
id: options.id,
|
|
116
|
+
name: options.name || options.id,
|
|
117
|
+
tools: options.tools || [],
|
|
118
|
+
transport: options.transport || "stdio",
|
|
119
|
+
description: options.description || options.name || options.id,
|
|
120
|
+
isExternal: true,
|
|
121
|
+
command: options.command,
|
|
122
|
+
args: options.args,
|
|
123
|
+
env: options.env,
|
|
124
|
+
});
|
|
125
|
+
}
|
|
@@ -56,7 +56,7 @@ export declare function getProviderModel(envVar: string, defaultModel: string):
|
|
|
56
56
|
/**
|
|
57
57
|
* Checks if provider credentials are available
|
|
58
58
|
* @param envVars Array of environment variable names to check
|
|
59
|
-
* @returns True if
|
|
59
|
+
* @returns True if one of the credentials is available
|
|
60
60
|
*/
|
|
61
61
|
export declare function hasProviderCredentials(envVars: string[]): boolean;
|
|
62
62
|
/**
|
|
@@ -135,7 +135,7 @@ export function getProviderModel(envVar, defaultModel) {
|
|
|
135
135
|
/**
|
|
136
136
|
* Checks if provider credentials are available
|
|
137
137
|
* @param envVars Array of environment variable names to check
|
|
138
|
-
* @returns True if
|
|
138
|
+
* @returns True if one of the credentials is available
|
|
139
139
|
*/
|
|
140
140
|
export function hasProviderCredentials(envVars) {
|
|
141
141
|
return envVars.some((envVar) => !!process.env[envVar]);
|
|
@@ -286,7 +286,7 @@ export function createOpenAICompatibleConfig() {
|
|
|
286
286
|
"1. Set OPENAI_COMPATIBLE_BASE_URL to your endpoint (e.g., https://api.openrouter.ai/api/v1)",
|
|
287
287
|
"2. Get API key from your OpenAI-compatible service:",
|
|
288
288
|
" • OpenRouter: https://openrouter.ai/keys",
|
|
289
|
-
" • vLLM: Use
|
|
289
|
+
" • vLLM: Use a random value for local deployments",
|
|
290
290
|
" • LiteLLM: Check your LiteLLM server configuration",
|
|
291
291
|
"3. Set OPENAI_COMPATIBLE_API_KEY to your API key",
|
|
292
292
|
"4. Optionally set OPENAI_COMPATIBLE_MODEL (will auto-discover if not set)",
|
|
@@ -487,13 +487,13 @@ export class ProviderHealthChecker {
|
|
|
487
487
|
return provider;
|
|
488
488
|
}
|
|
489
489
|
}
|
|
490
|
-
// Fallback to
|
|
491
|
-
const
|
|
492
|
-
if (
|
|
493
|
-
logger.info(`Using fallback healthy provider: ${
|
|
494
|
-
return
|
|
490
|
+
// Fallback to first healthy provider
|
|
491
|
+
const firstHealthyProvider = healthStatuses.find((h) => h.isHealthy);
|
|
492
|
+
if (firstHealthyProvider) {
|
|
493
|
+
logger.info(`Using fallback healthy provider: ${firstHealthyProvider.provider}`);
|
|
494
|
+
return firstHealthyProvider.provider;
|
|
495
495
|
}
|
|
496
|
-
// Last resort:
|
|
496
|
+
// Last resort: first configured provider
|
|
497
497
|
const anyConfigured = healthStatuses.find((h) => h.isConfigured);
|
|
498
498
|
if (anyConfigured) {
|
|
499
499
|
logger.warn(`Using configured but potentially unhealthy provider: ${anyConfigured.provider}`);
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* External MCP Server Manager
|
|
3
|
+
* Handles lifecycle management of external MCP servers including:
|
|
4
|
+
* - Process spawning and management
|
|
5
|
+
* - Health monitoring and automatic restart
|
|
6
|
+
* - Connection management and cleanup
|
|
7
|
+
* - Tool discovery and registration
|
|
8
|
+
*/
|
|
9
|
+
import { EventEmitter } from "events";
|
|
10
|
+
import { ToolDiscoveryService } from "./toolDiscoveryService.js";
|
|
11
|
+
import type { ExternalMCPServerInstance, ExternalMCPServerHealth, ExternalMCPConfigValidation, ExternalMCPOperationResult, ExternalMCPManagerConfig, ExternalMCPToolInfo } from "../types/externalMcp.js";
|
|
12
|
+
import type { MCPServerInfo } from "../types/mcpTypes.js";
|
|
13
|
+
import type { JsonObject } from "../types/common.js";
|
|
14
|
+
export declare class ExternalServerManager extends EventEmitter {
|
|
15
|
+
private servers;
|
|
16
|
+
private config;
|
|
17
|
+
private isShuttingDown;
|
|
18
|
+
private toolDiscovery;
|
|
19
|
+
private enableMainRegistryIntegration;
|
|
20
|
+
constructor(config?: ExternalMCPManagerConfig, options?: {
|
|
21
|
+
enableMainRegistryIntegration?: boolean;
|
|
22
|
+
});
|
|
23
|
+
/**
|
|
24
|
+
* Load MCP server configurations from .mcp-config.json file
|
|
25
|
+
* Automatically registers servers found in the configuration
|
|
26
|
+
* @param configPath Optional path to config file (defaults to .mcp-config.json in cwd)
|
|
27
|
+
* @returns Promise resolving to number of servers loaded
|
|
28
|
+
*/
|
|
29
|
+
loadMCPConfiguration(configPath?: string): Promise<{
|
|
30
|
+
serversLoaded: number;
|
|
31
|
+
errors: string[];
|
|
32
|
+
}>;
|
|
33
|
+
/**
|
|
34
|
+
* Validate external MCP server configuration
|
|
35
|
+
*/
|
|
36
|
+
validateConfig(config: MCPServerInfo): ExternalMCPConfigValidation;
|
|
37
|
+
/**
|
|
38
|
+
* Convert MCPServerInfo format (keeping for backward compatibility)
|
|
39
|
+
* Helper function for transitioning to zero-conversion architecture
|
|
40
|
+
*/
|
|
41
|
+
private convertConfigToMCPServerInfo;
|
|
42
|
+
/**
|
|
43
|
+
* Add a new external MCP server - Backward compatibility overload
|
|
44
|
+
*/
|
|
45
|
+
addServer(serverId: string, config: MCPServerInfo): Promise<ExternalMCPOperationResult<ExternalMCPServerInstance>>;
|
|
46
|
+
/**
|
|
47
|
+
* Add a new external MCP server - Updated to accept MCPServerInfo
|
|
48
|
+
*/
|
|
49
|
+
addServer(serverId: string, serverInfo: MCPServerInfo): Promise<ExternalMCPOperationResult<ExternalMCPServerInstance>>;
|
|
50
|
+
/**
|
|
51
|
+
* Remove an external MCP server
|
|
52
|
+
*/
|
|
53
|
+
removeServer(serverId: string): Promise<ExternalMCPOperationResult<void>>;
|
|
54
|
+
/**
|
|
55
|
+
* Start an external MCP server
|
|
56
|
+
*/
|
|
57
|
+
private startServer;
|
|
58
|
+
/**
|
|
59
|
+
* Stop an external MCP server
|
|
60
|
+
*/
|
|
61
|
+
private stopServer;
|
|
62
|
+
/**
|
|
63
|
+
* Update server status and emit events
|
|
64
|
+
*/
|
|
65
|
+
private updateServerStatus;
|
|
66
|
+
/**
|
|
67
|
+
* Handle server errors
|
|
68
|
+
*/
|
|
69
|
+
private handleServerError;
|
|
70
|
+
/**
|
|
71
|
+
* Handle server disconnection
|
|
72
|
+
*/
|
|
73
|
+
private handleServerDisconnection;
|
|
74
|
+
/**
|
|
75
|
+
* Schedule server restart with exponential backoff
|
|
76
|
+
*/
|
|
77
|
+
private scheduleRestart;
|
|
78
|
+
/**
|
|
79
|
+
* Start health monitoring for a server
|
|
80
|
+
*/
|
|
81
|
+
private startHealthMonitoring;
|
|
82
|
+
/**
|
|
83
|
+
* Perform health check on a server
|
|
84
|
+
*/
|
|
85
|
+
private performHealthCheck;
|
|
86
|
+
/**
|
|
87
|
+
* Get server instance - converted to ExternalMCPServerInstance for compatibility
|
|
88
|
+
*/
|
|
89
|
+
getServer(serverId: string): ExternalMCPServerInstance | undefined;
|
|
90
|
+
/**
|
|
91
|
+
* Get all servers - converted to ExternalMCPServerInstance for compatibility
|
|
92
|
+
*/
|
|
93
|
+
getAllServers(): Map<string, ExternalMCPServerInstance>;
|
|
94
|
+
/**
|
|
95
|
+
* List servers as MCPServerInfo - ZERO conversion needed
|
|
96
|
+
*/
|
|
97
|
+
listServers(): MCPServerInfo[];
|
|
98
|
+
/**
|
|
99
|
+
* Get server statuses
|
|
100
|
+
*/
|
|
101
|
+
getServerStatuses(): ExternalMCPServerHealth[];
|
|
102
|
+
/**
|
|
103
|
+
* Shutdown all servers
|
|
104
|
+
*/
|
|
105
|
+
shutdown(): Promise<void>;
|
|
106
|
+
/**
|
|
107
|
+
* Get manager statistics
|
|
108
|
+
*/
|
|
109
|
+
getStatistics(): {
|
|
110
|
+
totalServers: number;
|
|
111
|
+
connectedServers: number;
|
|
112
|
+
failedServers: number;
|
|
113
|
+
totalTools: number;
|
|
114
|
+
totalConnections: number;
|
|
115
|
+
totalErrors: number;
|
|
116
|
+
};
|
|
117
|
+
/**
|
|
118
|
+
* Discover tools from a server
|
|
119
|
+
*/
|
|
120
|
+
private discoverServerTools;
|
|
121
|
+
/**
|
|
122
|
+
* Register server tools with main tool registry for unified access
|
|
123
|
+
* This enables external MCP tools to be accessed via the main toolRegistry.executeTool()
|
|
124
|
+
*/
|
|
125
|
+
private registerServerToolsWithMainRegistry;
|
|
126
|
+
/**
|
|
127
|
+
* Unregister server tools from main tool registry
|
|
128
|
+
*/
|
|
129
|
+
private unregisterServerToolsFromMainRegistry;
|
|
130
|
+
/**
|
|
131
|
+
* Execute a tool on a specific server
|
|
132
|
+
*/
|
|
133
|
+
executeTool(serverId: string, toolName: string, parameters: JsonObject, options?: {
|
|
134
|
+
timeout?: number;
|
|
135
|
+
}): Promise<unknown>;
|
|
136
|
+
/**
|
|
137
|
+
* Get all tools from all servers
|
|
138
|
+
*/
|
|
139
|
+
getAllTools(): ExternalMCPToolInfo[];
|
|
140
|
+
/**
|
|
141
|
+
* Get tools for a specific server
|
|
142
|
+
*/
|
|
143
|
+
getServerTools(serverId: string): ExternalMCPToolInfo[];
|
|
144
|
+
/**
|
|
145
|
+
* Get tool discovery service
|
|
146
|
+
*/
|
|
147
|
+
getToolDiscovery(): ToolDiscoveryService;
|
|
148
|
+
}
|