@mcpmesh/sdk 0.8.0-beta.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 (145) hide show
  1. package/dist/__tests__/claude-handler.test.d.ts +7 -0
  2. package/dist/__tests__/claude-handler.test.d.ts.map +1 -0
  3. package/dist/__tests__/claude-handler.test.js +455 -0
  4. package/dist/__tests__/claude-handler.test.js.map +1 -0
  5. package/dist/__tests__/config.test.d.ts +7 -0
  6. package/dist/__tests__/config.test.d.ts.map +1 -0
  7. package/dist/__tests__/config.test.js +156 -0
  8. package/dist/__tests__/config.test.js.map +1 -0
  9. package/dist/__tests__/errors.test.d.ts +7 -0
  10. package/dist/__tests__/errors.test.d.ts.map +1 -0
  11. package/dist/__tests__/errors.test.js +170 -0
  12. package/dist/__tests__/errors.test.js.map +1 -0
  13. package/dist/__tests__/generic-handler.test.d.ts +7 -0
  14. package/dist/__tests__/generic-handler.test.d.ts.map +1 -0
  15. package/dist/__tests__/generic-handler.test.js +243 -0
  16. package/dist/__tests__/generic-handler.test.js.map +1 -0
  17. package/dist/__tests__/llm-provider.test.d.ts +7 -0
  18. package/dist/__tests__/llm-provider.test.d.ts.map +1 -0
  19. package/dist/__tests__/llm-provider.test.js +217 -0
  20. package/dist/__tests__/llm-provider.test.js.map +1 -0
  21. package/dist/__tests__/openai-handler.test.d.ts +7 -0
  22. package/dist/__tests__/openai-handler.test.d.ts.map +1 -0
  23. package/dist/__tests__/openai-handler.test.js +359 -0
  24. package/dist/__tests__/openai-handler.test.js.map +1 -0
  25. package/dist/__tests__/provider-handler-registry.test.d.ts +9 -0
  26. package/dist/__tests__/provider-handler-registry.test.d.ts.map +1 -0
  27. package/dist/__tests__/provider-handler-registry.test.js +187 -0
  28. package/dist/__tests__/provider-handler-registry.test.js.map +1 -0
  29. package/dist/__tests__/response-parser.test.d.ts +7 -0
  30. package/dist/__tests__/response-parser.test.d.ts.map +1 -0
  31. package/dist/__tests__/response-parser.test.js +360 -0
  32. package/dist/__tests__/response-parser.test.js.map +1 -0
  33. package/dist/__tests__/route.test.d.ts +7 -0
  34. package/dist/__tests__/route.test.d.ts.map +1 -0
  35. package/dist/__tests__/route.test.js +281 -0
  36. package/dist/__tests__/route.test.js.map +1 -0
  37. package/dist/__tests__/sse.test.d.ts +7 -0
  38. package/dist/__tests__/sse.test.d.ts.map +1 -0
  39. package/dist/__tests__/sse.test.js +172 -0
  40. package/dist/__tests__/sse.test.js.map +1 -0
  41. package/dist/__tests__/template.test.d.ts +7 -0
  42. package/dist/__tests__/template.test.d.ts.map +1 -0
  43. package/dist/__tests__/template.test.js +176 -0
  44. package/dist/__tests__/template.test.js.map +1 -0
  45. package/dist/__tests__/tracing.test.d.ts +7 -0
  46. package/dist/__tests__/tracing.test.d.ts.map +1 -0
  47. package/dist/__tests__/tracing.test.js +264 -0
  48. package/dist/__tests__/tracing.test.js.map +1 -0
  49. package/dist/agent.d.ts +165 -0
  50. package/dist/agent.d.ts.map +1 -0
  51. package/dist/agent.js +626 -0
  52. package/dist/agent.js.map +1 -0
  53. package/dist/api-runtime.d.ts +166 -0
  54. package/dist/api-runtime.d.ts.map +1 -0
  55. package/dist/api-runtime.js +459 -0
  56. package/dist/api-runtime.js.map +1 -0
  57. package/dist/config.d.ts +31 -0
  58. package/dist/config.d.ts.map +1 -0
  59. package/dist/config.js +60 -0
  60. package/dist/config.js.map +1 -0
  61. package/dist/debug.d.ts +47 -0
  62. package/dist/debug.d.ts.map +1 -0
  63. package/dist/debug.js +86 -0
  64. package/dist/debug.js.map +1 -0
  65. package/dist/errors.d.ts +99 -0
  66. package/dist/errors.d.ts.map +1 -0
  67. package/dist/errors.js +110 -0
  68. package/dist/errors.js.map +1 -0
  69. package/dist/express.d.ts +146 -0
  70. package/dist/express.d.ts.map +1 -0
  71. package/dist/express.js +371 -0
  72. package/dist/express.js.map +1 -0
  73. package/dist/index.d.ts +96 -0
  74. package/dist/index.d.ts.map +1 -0
  75. package/dist/index.js +107 -0
  76. package/dist/index.js.map +1 -0
  77. package/dist/llm-agent.d.ts +193 -0
  78. package/dist/llm-agent.d.ts.map +1 -0
  79. package/dist/llm-agent.js +634 -0
  80. package/dist/llm-agent.js.map +1 -0
  81. package/dist/llm-provider.d.ts +323 -0
  82. package/dist/llm-provider.d.ts.map +1 -0
  83. package/dist/llm-provider.js +446 -0
  84. package/dist/llm-provider.js.map +1 -0
  85. package/dist/llm.d.ts +194 -0
  86. package/dist/llm.d.ts.map +1 -0
  87. package/dist/llm.js +304 -0
  88. package/dist/llm.js.map +1 -0
  89. package/dist/provider-handlers/claude-handler.d.ts +98 -0
  90. package/dist/provider-handlers/claude-handler.d.ts.map +1 -0
  91. package/dist/provider-handlers/claude-handler.js +268 -0
  92. package/dist/provider-handlers/claude-handler.js.map +1 -0
  93. package/dist/provider-handlers/gemini-handler.d.ts +82 -0
  94. package/dist/provider-handlers/gemini-handler.d.ts.map +1 -0
  95. package/dist/provider-handlers/gemini-handler.js +152 -0
  96. package/dist/provider-handlers/gemini-handler.js.map +1 -0
  97. package/dist/provider-handlers/generic-handler.d.ts +78 -0
  98. package/dist/provider-handlers/generic-handler.d.ts.map +1 -0
  99. package/dist/provider-handlers/generic-handler.js +152 -0
  100. package/dist/provider-handlers/generic-handler.js.map +1 -0
  101. package/dist/provider-handlers/index.d.ts +29 -0
  102. package/dist/provider-handlers/index.d.ts.map +1 -0
  103. package/dist/provider-handlers/index.js +32 -0
  104. package/dist/provider-handlers/index.js.map +1 -0
  105. package/dist/provider-handlers/openai-handler.d.ts +86 -0
  106. package/dist/provider-handlers/openai-handler.d.ts.map +1 -0
  107. package/dist/provider-handlers/openai-handler.js +160 -0
  108. package/dist/provider-handlers/openai-handler.js.map +1 -0
  109. package/dist/provider-handlers/provider-handler-registry.d.ts +124 -0
  110. package/dist/provider-handlers/provider-handler-registry.d.ts.map +1 -0
  111. package/dist/provider-handlers/provider-handler-registry.js +180 -0
  112. package/dist/provider-handlers/provider-handler-registry.js.map +1 -0
  113. package/dist/provider-handlers/provider-handler.d.ts +245 -0
  114. package/dist/provider-handlers/provider-handler.d.ts.map +1 -0
  115. package/dist/provider-handlers/provider-handler.js +238 -0
  116. package/dist/provider-handlers/provider-handler.js.map +1 -0
  117. package/dist/proxy.d.ts +44 -0
  118. package/dist/proxy.d.ts.map +1 -0
  119. package/dist/proxy.js +324 -0
  120. package/dist/proxy.js.map +1 -0
  121. package/dist/response-parser.d.ts +103 -0
  122. package/dist/response-parser.d.ts.map +1 -0
  123. package/dist/response-parser.js +232 -0
  124. package/dist/response-parser.js.map +1 -0
  125. package/dist/route.d.ts +185 -0
  126. package/dist/route.d.ts.map +1 -0
  127. package/dist/route.js +310 -0
  128. package/dist/route.js.map +1 -0
  129. package/dist/sse.d.ts +45 -0
  130. package/dist/sse.d.ts.map +1 -0
  131. package/dist/sse.js +77 -0
  132. package/dist/sse.js.map +1 -0
  133. package/dist/template.d.ts +86 -0
  134. package/dist/template.d.ts.map +1 -0
  135. package/dist/template.js +206 -0
  136. package/dist/template.js.map +1 -0
  137. package/dist/tracing.d.ts +88 -0
  138. package/dist/tracing.d.ts.map +1 -0
  139. package/dist/tracing.js +193 -0
  140. package/dist/tracing.js.map +1 -0
  141. package/dist/types.d.ts +618 -0
  142. package/dist/types.d.ts.map +1 -0
  143. package/dist/types.js +5 -0
  144. package/dist/types.js.map +1 -0
  145. package/package.json +68 -0
@@ -0,0 +1,193 @@
1
+ /**
2
+ * MeshLlmAgent - Agentic loop implementation for LLM-powered tools.
3
+ *
4
+ * This class handles:
5
+ * - System prompt rendering (with Handlebars templates)
6
+ * - Agentic loop with tool execution
7
+ * - LLM provider calls (direct LiteLLM or mesh delegation)
8
+ * - Response parsing with Zod validation
9
+ * - Metadata tracking (tokens, latency, tool calls)
10
+ *
11
+ * @example
12
+ * ```typescript
13
+ * const agent = new MeshLlmAgent({
14
+ * provider: "claude",
15
+ * model: "anthropic/claude-sonnet-4-20250514",
16
+ * systemPrompt: "file://prompts/assistant.hbs",
17
+ * maxIterations: 10,
18
+ * returnSchema: ResponseSchema,
19
+ * });
20
+ *
21
+ * const result = await agent.run("Help me calculate 2+2", {
22
+ * templateContext: { user: "John" },
23
+ * tools: resolvedToolProxies,
24
+ * });
25
+ * ```
26
+ */
27
+ import type { ZodType } from "zod";
28
+ import type { LlmProviderSpec, LlmMeta, LlmMessage, LlmToolDefinition, LlmCompletionResponse, LlmToolProxy, LlmCallOptions, LlmMessageInput, LlmOutputMode } from "./types.js";
29
+ /**
30
+ * Configuration for MeshLlmAgent.
31
+ */
32
+ export interface MeshLlmAgentConfig {
33
+ /** Function ID (used for event matching) */
34
+ functionId: string;
35
+ /** LLM provider spec */
36
+ provider: LlmProviderSpec;
37
+ /** Model override */
38
+ model?: string;
39
+ /** System prompt template */
40
+ systemPrompt?: string;
41
+ /** Parameter name for template context */
42
+ contextParam?: string;
43
+ /** Max agentic loop iterations */
44
+ maxIterations: number;
45
+ /** Max tokens */
46
+ maxOutputTokens?: number;
47
+ /** Temperature */
48
+ temperature?: number;
49
+ /** Top-p */
50
+ topP?: number;
51
+ /** Stop sequences */
52
+ stop?: string[];
53
+ /** Return schema for validation */
54
+ returnSchema?: ZodType;
55
+ /** Output mode: strict, hint, or text */
56
+ outputMode?: LlmOutputMode;
57
+ }
58
+ /**
59
+ * Runtime context for agent execution.
60
+ */
61
+ export interface AgentRunContext {
62
+ /** Template context (from contextParam or runtime override) */
63
+ templateContext?: Record<string, unknown>;
64
+ /** Resolved tool proxies from mesh */
65
+ tools: LlmToolProxy[];
66
+ /** Resolved mesh provider (if using mesh delegation) */
67
+ meshProvider?: {
68
+ endpoint: string;
69
+ functionName: string;
70
+ model?: string;
71
+ };
72
+ /** Runtime overrides */
73
+ options?: LlmCallOptions;
74
+ }
75
+ /**
76
+ * Provider interface for making LLM completion calls.
77
+ */
78
+ export interface LlmProvider {
79
+ complete(model: string, messages: LlmMessage[], tools?: LlmToolDefinition[], options?: {
80
+ maxOutputTokens?: number;
81
+ temperature?: number;
82
+ topP?: number;
83
+ stop?: string[];
84
+ }): Promise<LlmCompletionResponse>;
85
+ }
86
+ /**
87
+ * Default LiteLLM provider using HTTP proxy.
88
+ * Assumes LiteLLM proxy is running at LITELLM_URL or localhost:4000.
89
+ */
90
+ export declare class LiteLLMProvider implements LlmProvider {
91
+ private baseUrl;
92
+ constructor(baseUrl?: string);
93
+ complete(model: string, messages: LlmMessage[], tools?: LlmToolDefinition[], options?: {
94
+ maxOutputTokens?: number;
95
+ temperature?: number;
96
+ topP?: number;
97
+ stop?: string[];
98
+ }): Promise<LlmCompletionResponse>;
99
+ }
100
+ /**
101
+ * Mesh provider that delegates to an LLM provider discovered via mesh.
102
+ */
103
+ export declare class MeshDelegatedProvider implements LlmProvider {
104
+ private endpoint;
105
+ private functionName;
106
+ constructor(endpoint: string, functionName: string);
107
+ complete(model: string, messages: LlmMessage[], tools?: LlmToolDefinition[], options?: {
108
+ maxOutputTokens?: number;
109
+ temperature?: number;
110
+ topP?: number;
111
+ stop?: string[];
112
+ }): Promise<LlmCompletionResponse>;
113
+ }
114
+ /**
115
+ * MeshLlmAgent - The core agentic loop implementation.
116
+ */
117
+ export declare class MeshLlmAgent<T = string> {
118
+ private config;
119
+ private responseParser;
120
+ private _meta;
121
+ private _systemPromptOverride;
122
+ constructor(config: MeshLlmAgentConfig);
123
+ /**
124
+ * Get metadata from the last run.
125
+ */
126
+ get meta(): LlmMeta | null;
127
+ /**
128
+ * Override the system prompt at runtime.
129
+ */
130
+ setSystemPrompt(prompt: string): void;
131
+ /**
132
+ * Get the effective system prompt (override or config).
133
+ */
134
+ private getSystemPrompt;
135
+ /**
136
+ * Run the agentic loop.
137
+ *
138
+ * @param messageInput - User message string or multi-turn message array
139
+ * @param context - Runtime context with tools and options
140
+ * @returns Parsed response (validated if schema provided)
141
+ */
142
+ run(messageInput: LlmMessageInput, context: AgentRunContext): Promise<T>;
143
+ /**
144
+ * Create a callable LlmAgent interface.
145
+ */
146
+ createCallable(context: AgentRunContext): {
147
+ (message: LlmMessageInput, options?: LlmCallOptions): Promise<T>;
148
+ readonly meta: LlmMeta | null;
149
+ readonly tools: LlmToolProxy[];
150
+ setSystemPrompt(prompt: string): void;
151
+ };
152
+ /**
153
+ * Resolve the LLM provider to use.
154
+ */
155
+ private resolveProvider;
156
+ /**
157
+ * Get provider name for metadata.
158
+ */
159
+ private getProviderName;
160
+ /**
161
+ * Get default model based on provider.
162
+ */
163
+ private getDefaultModel;
164
+ /**
165
+ * Build tool definitions from proxies.
166
+ */
167
+ private buildToolDefinitions;
168
+ /**
169
+ * Build tool schema section for system prompt injection.
170
+ * Helps the LLM understand available tools and their schemas.
171
+ */
172
+ private buildToolSchemaSection;
173
+ /**
174
+ * Build output schema section for system prompt injection.
175
+ * Guides the LLM to produce structured output matching the schema.
176
+ */
177
+ private buildOutputSchemaSection;
178
+ /**
179
+ * Execute a tool call and record metadata.
180
+ */
181
+ private executeToolCall;
182
+ }
183
+ /**
184
+ * Create a tool proxy from resolved tool info.
185
+ */
186
+ export declare function createLlmToolProxy(toolInfo: {
187
+ functionName: string;
188
+ capability: string;
189
+ endpoint: string;
190
+ agentId: string;
191
+ inputSchema?: string;
192
+ }, description?: string): LlmToolProxy;
193
+ //# sourceMappingURL=llm-agent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"llm-agent.d.ts","sourceRoot":"","sources":["../src/llm-agent.ts"],"names":[],"mappings":"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"}