@juspay/neurolink 7.37.0 → 7.37.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 +6 -0
- package/dist/cli/commands/config.d.ts +18 -18
- package/dist/cli/factories/commandFactory.d.ts +24 -0
- package/dist/cli/factories/commandFactory.js +297 -245
- package/dist/core/baseProvider.d.ts +40 -3
- package/dist/core/baseProvider.js +689 -352
- package/dist/core/constants.d.ts +2 -30
- package/dist/core/constants.js +15 -43
- package/dist/factories/providerFactory.js +23 -6
- package/dist/index.d.ts +3 -2
- package/dist/index.js +4 -3
- package/dist/lib/core/baseProvider.d.ts +40 -3
- package/dist/lib/core/baseProvider.js +689 -352
- package/dist/lib/core/constants.d.ts +2 -30
- package/dist/lib/core/constants.js +15 -43
- package/dist/lib/factories/providerFactory.js +23 -6
- package/dist/lib/index.d.ts +3 -2
- package/dist/lib/index.js +4 -3
- package/dist/lib/mcp/externalServerManager.js +2 -2
- package/dist/lib/mcp/registry.js +2 -2
- package/dist/lib/mcp/servers/agent/directToolsServer.js +19 -10
- package/dist/lib/mcp/toolRegistry.js +4 -8
- package/dist/lib/neurolink.d.ts +62 -27
- package/dist/lib/neurolink.js +415 -719
- package/dist/lib/providers/amazonBedrock.js +2 -2
- package/dist/lib/providers/googleVertex.d.ts +3 -23
- package/dist/lib/providers/googleVertex.js +14 -342
- package/dist/lib/providers/openAI.d.ts +23 -0
- package/dist/lib/providers/openAI.js +313 -6
- package/dist/lib/providers/sagemaker/language-model.d.ts +2 -2
- package/dist/lib/sdk/toolRegistration.js +18 -1
- package/dist/lib/types/common.d.ts +98 -0
- package/dist/lib/types/streamTypes.d.ts +13 -6
- package/dist/lib/types/typeAliases.d.ts +3 -2
- package/dist/lib/utils/parameterValidation.js +6 -25
- package/dist/lib/utils/promptRedaction.js +4 -4
- package/dist/lib/utils/schemaConversion.d.ts +14 -0
- package/dist/lib/utils/schemaConversion.js +140 -0
- package/dist/lib/utils/transformationUtils.js +143 -5
- package/dist/mcp/externalServerManager.js +2 -2
- package/dist/mcp/registry.js +2 -2
- package/dist/mcp/servers/agent/directToolsServer.js +19 -10
- package/dist/mcp/toolRegistry.js +4 -8
- package/dist/neurolink.d.ts +62 -27
- package/dist/neurolink.js +415 -719
- package/dist/providers/amazonBedrock.js +2 -2
- package/dist/providers/googleVertex.d.ts +3 -23
- package/dist/providers/googleVertex.js +14 -342
- package/dist/providers/openAI.d.ts +23 -0
- package/dist/providers/openAI.js +313 -6
- package/dist/providers/sagemaker/language-model.d.ts +2 -2
- package/dist/sdk/toolRegistration.js +18 -1
- package/dist/types/common.d.ts +98 -0
- package/dist/types/streamTypes.d.ts +13 -6
- package/dist/types/typeAliases.d.ts +3 -2
- package/dist/utils/parameterValidation.js +6 -25
- package/dist/utils/promptRedaction.js +4 -4
- package/dist/utils/schemaConversion.d.ts +14 -0
- package/dist/utils/schemaConversion.js +140 -0
- package/dist/utils/transformationUtils.js +143 -5
- package/package.json +3 -2
package/dist/core/constants.d.ts
CHANGED
@@ -4,8 +4,8 @@
|
|
4
4
|
*/
|
5
5
|
export declare const DEFAULT_MAX_TOKENS: undefined;
|
6
6
|
export declare const DEFAULT_TEMPERATURE = 0.7;
|
7
|
-
export declare const DEFAULT_TIMEOUT =
|
8
|
-
export declare const DEFAULT_MAX_STEPS =
|
7
|
+
export declare const DEFAULT_TIMEOUT = 60000;
|
8
|
+
export declare const DEFAULT_MAX_STEPS = 200;
|
9
9
|
export declare const STEP_LIMITS: {
|
10
10
|
min: number;
|
11
11
|
max: number;
|
@@ -31,49 +31,21 @@ export declare const PROVIDER_CONFIG: {
|
|
31
31
|
};
|
32
32
|
export declare const PROVIDER_MAX_TOKENS: {
|
33
33
|
anthropic: {
|
34
|
-
"claude-3-haiku-20240307": number;
|
35
|
-
"claude-3-5-sonnet-20241022": number;
|
36
|
-
"claude-3-opus-20240229": number;
|
37
|
-
"claude-3-5-sonnet-20240620": number;
|
38
34
|
default: number;
|
39
35
|
};
|
40
36
|
openai: {
|
41
|
-
"gpt-4o": number;
|
42
|
-
"gpt-4o-mini": number;
|
43
|
-
"gpt-3.5-turbo": number;
|
44
|
-
"gpt-4": number;
|
45
|
-
"gpt-4-turbo": number;
|
46
37
|
default: number;
|
47
38
|
};
|
48
39
|
"google-ai": {
|
49
|
-
"gemini-1.5-pro": number;
|
50
|
-
"gemini-1.5-flash": number;
|
51
|
-
"gemini-2.5-pro": number;
|
52
|
-
"gemini-2.5-flash": number;
|
53
|
-
"gemini-pro": number;
|
54
40
|
default: number;
|
55
41
|
};
|
56
42
|
vertex: {
|
57
|
-
"gemini-1.5-pro": number;
|
58
|
-
"gemini-1.5-flash": number;
|
59
|
-
"gemini-2.5-pro": number;
|
60
|
-
"gemini-2.5-flash": number;
|
61
|
-
"claude-4.0-sonnet": number;
|
62
43
|
default: number;
|
63
44
|
};
|
64
45
|
bedrock: {
|
65
|
-
"anthropic.claude-3-sonnet-20240229-v1:0": number;
|
66
|
-
"anthropic.claude-3-haiku-20240307-v1:0": number;
|
67
|
-
"anthropic.claude-3-5-sonnet-20240620-v1:0": number;
|
68
46
|
default: number;
|
69
47
|
};
|
70
48
|
azure: {
|
71
|
-
"gpt-4o": number;
|
72
|
-
"gpt-4o-mini": number;
|
73
|
-
"gpt-4.1": number;
|
74
|
-
"gpt-3.5-turbo": number;
|
75
|
-
"gpt-4": number;
|
76
|
-
"gpt-4-turbo": number;
|
77
49
|
default: number;
|
78
50
|
};
|
79
51
|
ollama: {
|
package/dist/core/constants.js
CHANGED
@@ -5,12 +5,12 @@
|
|
5
5
|
// Core AI Generation Defaults
|
6
6
|
export const DEFAULT_MAX_TOKENS = undefined; // Unlimited by default - let providers decide their own limits
|
7
7
|
export const DEFAULT_TEMPERATURE = 0.7;
|
8
|
-
export const DEFAULT_TIMEOUT =
|
9
|
-
export const DEFAULT_MAX_STEPS =
|
8
|
+
export const DEFAULT_TIMEOUT = 60000;
|
9
|
+
export const DEFAULT_MAX_STEPS = 200;
|
10
10
|
// Step execution limits
|
11
11
|
export const STEP_LIMITS = {
|
12
12
|
min: 1,
|
13
|
-
max:
|
13
|
+
max: 500,
|
14
14
|
default: DEFAULT_MAX_STEPS,
|
15
15
|
};
|
16
16
|
// Specialized Use Case Defaults
|
@@ -33,68 +33,40 @@ export const PROVIDER_CONFIG = {
|
|
33
33
|
temperature: 0.4,
|
34
34
|
},
|
35
35
|
};
|
36
|
-
// Provider-specific maxTokens limits
|
36
|
+
// Provider-specific maxTokens limits
|
37
37
|
export const PROVIDER_MAX_TOKENS = {
|
38
38
|
anthropic: {
|
39
|
-
|
40
|
-
"claude-3-5-sonnet-20241022": 4096,
|
41
|
-
"claude-3-opus-20240229": 4096,
|
42
|
-
"claude-3-5-sonnet-20240620": 4096,
|
43
|
-
default: 4096, // Conservative default for Anthropic
|
39
|
+
default: 64000,
|
44
40
|
},
|
45
41
|
openai: {
|
46
|
-
|
47
|
-
"gpt-4o-mini": 16384,
|
48
|
-
"gpt-3.5-turbo": 4096,
|
49
|
-
"gpt-4": 8192,
|
50
|
-
"gpt-4-turbo": 4096,
|
51
|
-
default: 8192, // OpenAI generally supports higher limits
|
42
|
+
default: 500000,
|
52
43
|
},
|
53
44
|
"google-ai": {
|
54
|
-
|
55
|
-
"gemini-1.5-flash": 8192,
|
56
|
-
"gemini-2.5-pro": 8192,
|
57
|
-
"gemini-2.5-flash": 8192,
|
58
|
-
"gemini-pro": 4096,
|
59
|
-
default: 4096, // Conservative default due to 500 errors at high limits
|
45
|
+
default: 64000,
|
60
46
|
},
|
61
47
|
vertex: {
|
62
|
-
|
63
|
-
"gemini-1.5-flash": 8192,
|
64
|
-
"gemini-2.5-pro": 8192,
|
65
|
-
"gemini-2.5-flash": 8192,
|
66
|
-
"claude-4.0-sonnet": 4096,
|
67
|
-
default: 4096,
|
48
|
+
default: 64000,
|
68
49
|
},
|
69
50
|
bedrock: {
|
70
|
-
|
71
|
-
"anthropic.claude-3-haiku-20240307-v1:0": 4096,
|
72
|
-
"anthropic.claude-3-5-sonnet-20240620-v1:0": 4096,
|
73
|
-
default: 4096,
|
51
|
+
default: 64000,
|
74
52
|
},
|
75
53
|
azure: {
|
76
|
-
|
77
|
-
"gpt-4o-mini": 16384,
|
78
|
-
"gpt-4.1": 16384,
|
79
|
-
"gpt-3.5-turbo": 4096,
|
80
|
-
"gpt-4": 8192,
|
81
|
-
"gpt-4-turbo": 4096,
|
82
|
-
default: 8192, // Azure OpenAI generally supports similar limits to OpenAI
|
54
|
+
default: 64000,
|
83
55
|
},
|
84
56
|
ollama: {
|
85
|
-
default:
|
57
|
+
default: 64000,
|
86
58
|
},
|
87
59
|
litellm: {
|
88
|
-
default:
|
60
|
+
default: 500000,
|
89
61
|
},
|
90
|
-
default:
|
62
|
+
default: 64000,
|
91
63
|
};
|
92
64
|
// CLI Validation Limits
|
93
65
|
export const CLI_LIMITS = {
|
94
66
|
maxTokens: {
|
95
67
|
min: 1,
|
96
|
-
max:
|
97
|
-
default:
|
68
|
+
max: 64000,
|
69
|
+
default: DEFAULT_MAX_TOKENS,
|
98
70
|
},
|
99
71
|
temperature: {
|
100
72
|
min: 0,
|
@@ -49,16 +49,33 @@ export class ProviderFactory {
|
|
49
49
|
model = model || registration.defaultModel;
|
50
50
|
}
|
51
51
|
try {
|
52
|
+
if (typeof registration.constructor !== "function") {
|
53
|
+
throw new Error(`Invalid constructor for provider ${providerName}: not a function`);
|
54
|
+
}
|
52
55
|
let result;
|
53
56
|
try {
|
54
|
-
|
55
|
-
|
57
|
+
const factoryResult = registration.constructor(model, providerName, sdk);
|
58
|
+
// Handle both sync and async results
|
59
|
+
result =
|
60
|
+
factoryResult instanceof Promise
|
61
|
+
? await factoryResult
|
62
|
+
: factoryResult;
|
56
63
|
}
|
57
|
-
catch {
|
58
|
-
|
59
|
-
|
64
|
+
catch (factoryError) {
|
65
|
+
if (registration.constructor.prototype &&
|
66
|
+
registration.constructor.prototype.constructor ===
|
67
|
+
registration.constructor) {
|
68
|
+
try {
|
69
|
+
result = new registration.constructor(model, providerName, sdk);
|
70
|
+
}
|
71
|
+
catch (constructorError) {
|
72
|
+
throw new Error(`Both factory function and constructor failed. Factory error: ${factoryError}. Constructor error: ${constructorError}`);
|
73
|
+
}
|
74
|
+
}
|
75
|
+
else {
|
76
|
+
throw factoryError;
|
77
|
+
}
|
60
78
|
}
|
61
|
-
// Return result (no need to await again if already awaited in try block)
|
62
79
|
return result;
|
63
80
|
}
|
64
81
|
catch (error) {
|
package/dist/index.d.ts
CHANGED
@@ -17,7 +17,8 @@ export { BedrockModels, OpenAIModels, VertexModels, DEFAULT_PROVIDER_CONFIGS, }
|
|
17
17
|
export { getBestProvider, getAvailableProviders, isValidProvider, } from "./utils/providerUtils.js";
|
18
18
|
export { dynamicModelProvider } from "./core/dynamicModels.js";
|
19
19
|
export type { DynamicModelConfig, ModelRegistry } from "./types/modelTypes.js";
|
20
|
-
|
20
|
+
import { NeuroLink } from "./neurolink.js";
|
21
|
+
export { NeuroLink };
|
21
22
|
export type { ProviderStatus, MCPStatus } from "./neurolink.js";
|
22
23
|
export type { MCPServerInfo } from "./types/mcpTypes.js";
|
23
24
|
export type { NeuroLinkMiddleware, MiddlewareContext, MiddlewareFactoryOptions, MiddlewarePreset, MiddlewareConfig, } from "./types/middlewareTypes.js";
|
@@ -102,4 +103,4 @@ export type { TextGenerationOptions, TextGenerationResult, AnalyticsData, Evalua
|
|
102
103
|
* console.log(result.content);
|
103
104
|
* ```
|
104
105
|
*/
|
105
|
-
export declare function generateText(options: import("./types
|
106
|
+
export declare function generateText(options: import("./core/types.js").TextGenerationOptions): Promise<import("./core/types.js").TextGenerationResult>;
|
package/dist/index.js
CHANGED
@@ -17,7 +17,8 @@ export { getBestProvider, getAvailableProviders, isValidProvider, } from "./util
|
|
17
17
|
// Dynamic Models exports
|
18
18
|
export { dynamicModelProvider } from "./core/dynamicModels.js";
|
19
19
|
// Main NeuroLink wrapper class and diagnostic types
|
20
|
-
|
20
|
+
import { NeuroLink } from "./neurolink.js";
|
21
|
+
export { NeuroLink };
|
21
22
|
export { MiddlewareFactory } from "./middleware/factory.js";
|
22
23
|
// Version
|
23
24
|
export const VERSION = "1.0.0";
|
@@ -127,7 +128,7 @@ export function getTelemetryStatus() {
|
|
127
128
|
* ```
|
128
129
|
*/
|
129
130
|
export async function generateText(options) {
|
130
|
-
//
|
131
|
-
const
|
131
|
+
// Create instance on-demand without auto-instantiation
|
132
|
+
const neurolink = new NeuroLink();
|
132
133
|
return await neurolink.generateText(options);
|
133
134
|
}
|
@@ -34,6 +34,39 @@ export declare abstract class BaseProvider implements AIProvider {
|
|
34
34
|
* When tools are involved, falls back to generate() with synthetic streaming
|
35
35
|
*/
|
36
36
|
stream(optionsOrPrompt: StreamOptions | string, analysisSchema?: ValidationSchema): Promise<StreamResult>;
|
37
|
+
/**
|
38
|
+
* Prepare generation context including tools and model
|
39
|
+
*/
|
40
|
+
private prepareGenerationContext;
|
41
|
+
/**
|
42
|
+
* Build messages array for generation
|
43
|
+
*/
|
44
|
+
private buildMessages;
|
45
|
+
/**
|
46
|
+
* Execute the generation with AI SDK
|
47
|
+
*/
|
48
|
+
private executeGeneration;
|
49
|
+
/**
|
50
|
+
* Log generation completion information
|
51
|
+
*/
|
52
|
+
private logGenerationComplete;
|
53
|
+
/**
|
54
|
+
* Record performance metrics
|
55
|
+
*/
|
56
|
+
private recordPerformanceMetrics;
|
57
|
+
/**
|
58
|
+
* Extract tool information from generation result
|
59
|
+
*/
|
60
|
+
private extractToolInformation;
|
61
|
+
/**
|
62
|
+
* Format the enhanced result
|
63
|
+
*/
|
64
|
+
private formatEnhancedResult;
|
65
|
+
/**
|
66
|
+
* Analyze AI response structure and log detailed debugging information
|
67
|
+
* Extracted from generate method to reduce complexity
|
68
|
+
*/
|
69
|
+
private analyzeAIResponse;
|
37
70
|
/**
|
38
71
|
* Text generation method - implements AIProvider interface
|
39
72
|
* Tools are always available unless explicitly disabled
|
@@ -85,12 +118,17 @@ export declare abstract class BaseProvider implements AIProvider {
|
|
85
118
|
private isZodSchema;
|
86
119
|
/**
|
87
120
|
* Convert tool execution result from MCP format to standard format
|
121
|
+
* Handles tool failures gracefully to prevent stream termination
|
88
122
|
*/
|
89
123
|
private convertToolResult;
|
90
124
|
/**
|
91
125
|
* Create a custom tool from tool definition
|
92
126
|
*/
|
93
127
|
private createCustomToolFromDefinition;
|
128
|
+
/**
|
129
|
+
* Process direct tools with event emission wrapping
|
130
|
+
*/
|
131
|
+
private processDirectTools;
|
94
132
|
/**
|
95
133
|
* Process custom tools from setupToolExecutor
|
96
134
|
*/
|
@@ -117,10 +155,9 @@ export declare abstract class BaseProvider implements AIProvider {
|
|
117
155
|
*/
|
118
156
|
private calculateActualCost;
|
119
157
|
/**
|
120
|
-
*
|
121
|
-
* Handles common MCP schema patterns safely
|
158
|
+
* Create a permissive Zod schema that accepts all parameters as-is
|
122
159
|
*/
|
123
|
-
private
|
160
|
+
private createPermissiveZodSchema;
|
124
161
|
/**
|
125
162
|
* Set session context for MCP tools
|
126
163
|
*/
|