@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.
Files changed (61) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/cli/commands/config.d.ts +18 -18
  3. package/dist/cli/factories/commandFactory.d.ts +24 -0
  4. package/dist/cli/factories/commandFactory.js +297 -245
  5. package/dist/core/baseProvider.d.ts +40 -3
  6. package/dist/core/baseProvider.js +689 -352
  7. package/dist/core/constants.d.ts +2 -30
  8. package/dist/core/constants.js +15 -43
  9. package/dist/factories/providerFactory.js +23 -6
  10. package/dist/index.d.ts +3 -2
  11. package/dist/index.js +4 -3
  12. package/dist/lib/core/baseProvider.d.ts +40 -3
  13. package/dist/lib/core/baseProvider.js +689 -352
  14. package/dist/lib/core/constants.d.ts +2 -30
  15. package/dist/lib/core/constants.js +15 -43
  16. package/dist/lib/factories/providerFactory.js +23 -6
  17. package/dist/lib/index.d.ts +3 -2
  18. package/dist/lib/index.js +4 -3
  19. package/dist/lib/mcp/externalServerManager.js +2 -2
  20. package/dist/lib/mcp/registry.js +2 -2
  21. package/dist/lib/mcp/servers/agent/directToolsServer.js +19 -10
  22. package/dist/lib/mcp/toolRegistry.js +4 -8
  23. package/dist/lib/neurolink.d.ts +62 -27
  24. package/dist/lib/neurolink.js +415 -719
  25. package/dist/lib/providers/amazonBedrock.js +2 -2
  26. package/dist/lib/providers/googleVertex.d.ts +3 -23
  27. package/dist/lib/providers/googleVertex.js +14 -342
  28. package/dist/lib/providers/openAI.d.ts +23 -0
  29. package/dist/lib/providers/openAI.js +313 -6
  30. package/dist/lib/providers/sagemaker/language-model.d.ts +2 -2
  31. package/dist/lib/sdk/toolRegistration.js +18 -1
  32. package/dist/lib/types/common.d.ts +98 -0
  33. package/dist/lib/types/streamTypes.d.ts +13 -6
  34. package/dist/lib/types/typeAliases.d.ts +3 -2
  35. package/dist/lib/utils/parameterValidation.js +6 -25
  36. package/dist/lib/utils/promptRedaction.js +4 -4
  37. package/dist/lib/utils/schemaConversion.d.ts +14 -0
  38. package/dist/lib/utils/schemaConversion.js +140 -0
  39. package/dist/lib/utils/transformationUtils.js +143 -5
  40. package/dist/mcp/externalServerManager.js +2 -2
  41. package/dist/mcp/registry.js +2 -2
  42. package/dist/mcp/servers/agent/directToolsServer.js +19 -10
  43. package/dist/mcp/toolRegistry.js +4 -8
  44. package/dist/neurolink.d.ts +62 -27
  45. package/dist/neurolink.js +415 -719
  46. package/dist/providers/amazonBedrock.js +2 -2
  47. package/dist/providers/googleVertex.d.ts +3 -23
  48. package/dist/providers/googleVertex.js +14 -342
  49. package/dist/providers/openAI.d.ts +23 -0
  50. package/dist/providers/openAI.js +313 -6
  51. package/dist/providers/sagemaker/language-model.d.ts +2 -2
  52. package/dist/sdk/toolRegistration.js +18 -1
  53. package/dist/types/common.d.ts +98 -0
  54. package/dist/types/streamTypes.d.ts +13 -6
  55. package/dist/types/typeAliases.d.ts +3 -2
  56. package/dist/utils/parameterValidation.js +6 -25
  57. package/dist/utils/promptRedaction.js +4 -4
  58. package/dist/utils/schemaConversion.d.ts +14 -0
  59. package/dist/utils/schemaConversion.js +140 -0
  60. package/dist/utils/transformationUtils.js +143 -5
  61. package/package.json +3 -2
@@ -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 = 30000;
8
- export declare const DEFAULT_MAX_STEPS = 5;
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: {
@@ -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 = 30000;
9
- export const DEFAULT_MAX_STEPS = 5; // Default multi-turn tool execution 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: 20,
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 (discovered through testing)
36
+ // Provider-specific maxTokens limits
37
37
  export const PROVIDER_MAX_TOKENS = {
38
38
  anthropic: {
39
- "claude-3-haiku-20240307": 4096,
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
- "gpt-4o": 16384,
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
- "gemini-1.5-pro": 8192,
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
- "gemini-1.5-pro": 8192,
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
- "anthropic.claude-3-sonnet-20240229-v1:0": 4096,
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
- "gpt-4o": 16384,
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: 8192, // Ollama typically supports higher limits
57
+ default: 64000,
86
58
  },
87
59
  litellm: {
88
- default: 4096, // Conservative default
60
+ default: 500000,
89
61
  },
90
- default: 4096, // Safe default across all providers
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: 50000,
97
- default: undefined, // No default limit - unlimited by 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
- // Try as async factory function first (most providers are async functions)
55
- result = await registration.constructor(model, providerName, sdk);
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
- // Fallback to constructor - ensure parameters are maintained
59
- result = new registration.constructor(model, providerName, sdk);
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
- export { NeuroLink } from "./neurolink.js";
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/index.js").TextGenerationOptions): Promise<import("./types/index.js").TextGenerationResult>;
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
- export { NeuroLink } from "./neurolink.js";
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
- // Import neurolink instance to avoid circular dependencies
131
- const { neurolink } = await import("./neurolink.js");
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
- * Convert MCP JSON Schema to Zod schema for AI SDK tools
121
- * Handles common MCP schema patterns safely
158
+ * Create a permissive Zod schema that accepts all parameters as-is
122
159
  */
123
- private convertMCPSchemaToZod;
160
+ private createPermissiveZodSchema;
124
161
  /**
125
162
  * Set session context for MCP tools
126
163
  */