@metorial/sdk 1.0.0-rc.6 → 1.1.0
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/dist/index.cjs +512 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +44 -14
- package/dist/index.d.ts +44 -14
- package/dist/index.js +512 -0
- package/dist/index.js.map +1 -1
- package/package.json +29 -5
package/dist/index.cjs
CHANGED
|
@@ -2,6 +2,403 @@
|
|
|
2
2
|
|
|
3
3
|
var core = require('@metorial/core');
|
|
4
4
|
var mcpSession = require('@metorial/mcp-session');
|
|
5
|
+
var openai = require('@metorial/openai');
|
|
6
|
+
var anthropic = require('@metorial/anthropic');
|
|
7
|
+
var deepseek = require('@metorial/deepseek');
|
|
8
|
+
var google = require('@metorial/google');
|
|
9
|
+
var mistral = require('@metorial/mistral');
|
|
10
|
+
var xai = require('@metorial/xai');
|
|
11
|
+
var togetherai = require('@metorial/togetherai');
|
|
12
|
+
|
|
13
|
+
// src/metorial.ts
|
|
14
|
+
var runWithOpenAI = async (config) => {
|
|
15
|
+
let {
|
|
16
|
+
message,
|
|
17
|
+
serverDeployments,
|
|
18
|
+
client,
|
|
19
|
+
model,
|
|
20
|
+
maxSteps = 25,
|
|
21
|
+
tools: requestedTools,
|
|
22
|
+
withProviderSession,
|
|
23
|
+
...openaiOptions
|
|
24
|
+
} = config;
|
|
25
|
+
return withProviderSession(
|
|
26
|
+
openai.metorialOpenAI.chatCompletions,
|
|
27
|
+
{
|
|
28
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
29
|
+
},
|
|
30
|
+
async (session) => {
|
|
31
|
+
let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
|
|
32
|
+
let messages = [
|
|
33
|
+
{ role: "user", content: message }
|
|
34
|
+
];
|
|
35
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
36
|
+
let response = await client.chat.completions.create({
|
|
37
|
+
model,
|
|
38
|
+
messages,
|
|
39
|
+
tools,
|
|
40
|
+
...openaiOptions
|
|
41
|
+
});
|
|
42
|
+
let choice = response.choices[0];
|
|
43
|
+
if (!choice.message.tool_calls) {
|
|
44
|
+
return {
|
|
45
|
+
text: choice.message.content || "",
|
|
46
|
+
steps: step + 1
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
let toolResponses = await session.callTools(choice.message.tool_calls);
|
|
50
|
+
messages.push(
|
|
51
|
+
{ role: "assistant", tool_calls: choice.message.tool_calls },
|
|
52
|
+
...toolResponses
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
56
|
+
}
|
|
57
|
+
);
|
|
58
|
+
};
|
|
59
|
+
var runWithAnthropic = async (config) => {
|
|
60
|
+
let {
|
|
61
|
+
message,
|
|
62
|
+
serverDeployments,
|
|
63
|
+
client,
|
|
64
|
+
model,
|
|
65
|
+
maxSteps = 25,
|
|
66
|
+
tools: requestedTools,
|
|
67
|
+
withProviderSession,
|
|
68
|
+
max_tokens = 4096,
|
|
69
|
+
...anthropicOptions
|
|
70
|
+
} = config;
|
|
71
|
+
return withProviderSession(
|
|
72
|
+
anthropic.metorialAnthropic,
|
|
73
|
+
{
|
|
74
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
75
|
+
},
|
|
76
|
+
async (session) => {
|
|
77
|
+
let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
|
|
78
|
+
let messages = [
|
|
79
|
+
{ role: "user", content: message }
|
|
80
|
+
];
|
|
81
|
+
let uniqueTools = Array.from(new Map(tools.map((t) => [t.name, t])).values());
|
|
82
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
83
|
+
let response = await client.messages.create({
|
|
84
|
+
model,
|
|
85
|
+
max_tokens,
|
|
86
|
+
messages,
|
|
87
|
+
tools: uniqueTools,
|
|
88
|
+
...anthropicOptions
|
|
89
|
+
});
|
|
90
|
+
if (response.stop_reason !== "tool_use") {
|
|
91
|
+
let textContent = response.content.find(
|
|
92
|
+
(block) => block.type === "text"
|
|
93
|
+
);
|
|
94
|
+
return {
|
|
95
|
+
text: (textContent == null ? void 0 : textContent.text) || "",
|
|
96
|
+
steps: step + 1
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
let toolUseBlocks = response.content.filter(
|
|
100
|
+
(block) => block.type === "tool_use"
|
|
101
|
+
);
|
|
102
|
+
let toolResponse = await session.callTools(toolUseBlocks);
|
|
103
|
+
let toolResponseMessage = {
|
|
104
|
+
role: "user",
|
|
105
|
+
content: toolResponse.content.map((block) => ({
|
|
106
|
+
type: "tool_result",
|
|
107
|
+
tool_use_id: block.tool_use_id,
|
|
108
|
+
content: block.content
|
|
109
|
+
}))
|
|
110
|
+
};
|
|
111
|
+
messages.push(
|
|
112
|
+
{ role: "assistant", content: response.content },
|
|
113
|
+
toolResponseMessage
|
|
114
|
+
);
|
|
115
|
+
}
|
|
116
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
117
|
+
}
|
|
118
|
+
);
|
|
119
|
+
};
|
|
120
|
+
var runWithDeepSeek = async (config) => {
|
|
121
|
+
let {
|
|
122
|
+
message,
|
|
123
|
+
serverDeployments,
|
|
124
|
+
client,
|
|
125
|
+
model,
|
|
126
|
+
maxSteps = 25,
|
|
127
|
+
tools: requestedTools,
|
|
128
|
+
withProviderSession,
|
|
129
|
+
...deepseekOptions
|
|
130
|
+
} = config;
|
|
131
|
+
return withProviderSession(
|
|
132
|
+
deepseek.metorialDeepseek,
|
|
133
|
+
{
|
|
134
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
135
|
+
},
|
|
136
|
+
async (session) => {
|
|
137
|
+
let tools = requestedTools ? session.tools.filter((t) => {
|
|
138
|
+
var _a;
|
|
139
|
+
return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
|
|
140
|
+
}) : session.tools;
|
|
141
|
+
let uniqueTools = Array.from(
|
|
142
|
+
new Map(tools.map((t) => {
|
|
143
|
+
var _a;
|
|
144
|
+
return [((_a = t.function) == null ? void 0 : _a.name) || t.name, t];
|
|
145
|
+
})).values()
|
|
146
|
+
);
|
|
147
|
+
let messages = [
|
|
148
|
+
{ role: "user", content: message }
|
|
149
|
+
];
|
|
150
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
151
|
+
let response = await client.chat.completions.create({
|
|
152
|
+
model,
|
|
153
|
+
messages,
|
|
154
|
+
tools: uniqueTools,
|
|
155
|
+
...deepseekOptions
|
|
156
|
+
});
|
|
157
|
+
let choice = response.choices[0];
|
|
158
|
+
if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
|
|
159
|
+
return {
|
|
160
|
+
text: choice.message.content || "",
|
|
161
|
+
steps: step + 1
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
let toolResponses = await session.callTools(choice.message.tool_calls);
|
|
165
|
+
messages.push(
|
|
166
|
+
{ role: "assistant", tool_calls: choice.message.tool_calls },
|
|
167
|
+
...toolResponses
|
|
168
|
+
);
|
|
169
|
+
}
|
|
170
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
171
|
+
}
|
|
172
|
+
);
|
|
173
|
+
};
|
|
174
|
+
var runWithGoogle = async (config) => {
|
|
175
|
+
let {
|
|
176
|
+
message,
|
|
177
|
+
serverDeployments,
|
|
178
|
+
client,
|
|
179
|
+
model,
|
|
180
|
+
maxSteps = 25,
|
|
181
|
+
tools: requestedTools,
|
|
182
|
+
withProviderSession,
|
|
183
|
+
...googleOptions
|
|
184
|
+
} = config;
|
|
185
|
+
return withProviderSession(
|
|
186
|
+
google.metorialGoogle,
|
|
187
|
+
{
|
|
188
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
189
|
+
},
|
|
190
|
+
async (session) => {
|
|
191
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i;
|
|
192
|
+
let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
|
|
193
|
+
let response = await client.models.generateContent({
|
|
194
|
+
model,
|
|
195
|
+
contents: [
|
|
196
|
+
{
|
|
197
|
+
role: "user",
|
|
198
|
+
parts: [{ text: message }]
|
|
199
|
+
}
|
|
200
|
+
],
|
|
201
|
+
config: {
|
|
202
|
+
tools,
|
|
203
|
+
...googleOptions
|
|
204
|
+
}
|
|
205
|
+
});
|
|
206
|
+
let text = (_e = (_d = (_c = (_b = (_a = response.candidates) == null ? void 0 : _a[0]) == null ? void 0 : _b.content) == null ? void 0 : _c.parts) == null ? void 0 : _d[0]) == null ? void 0 : _e.text;
|
|
207
|
+
let functionCalls = (_i = (_h = (_g = (_f = response.candidates) == null ? void 0 : _f[0]) == null ? void 0 : _g.content) == null ? void 0 : _h.parts) == null ? void 0 : _i.filter((part) => part.functionCall).map((part) => part.functionCall);
|
|
208
|
+
if (functionCalls && functionCalls.length > 0) {
|
|
209
|
+
let toolResponses = await session.callTools(functionCalls);
|
|
210
|
+
return {
|
|
211
|
+
text: text || "",
|
|
212
|
+
toolResponses,
|
|
213
|
+
steps: 1
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
return {
|
|
217
|
+
text: text || "",
|
|
218
|
+
steps: 1
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
);
|
|
222
|
+
};
|
|
223
|
+
var extractTextFromContent = (content) => {
|
|
224
|
+
if (typeof content === "string") {
|
|
225
|
+
return content;
|
|
226
|
+
}
|
|
227
|
+
if (Array.isArray(content)) {
|
|
228
|
+
return content.filter((chunk) => chunk && typeof chunk === "object").map((chunk) => chunk.text || chunk.content || JSON.stringify(chunk)).join("");
|
|
229
|
+
}
|
|
230
|
+
return "";
|
|
231
|
+
};
|
|
232
|
+
var runWithMistral = async (config) => {
|
|
233
|
+
let {
|
|
234
|
+
message,
|
|
235
|
+
serverDeployments,
|
|
236
|
+
client,
|
|
237
|
+
model,
|
|
238
|
+
maxSteps = 25,
|
|
239
|
+
tools: requestedTools,
|
|
240
|
+
withProviderSession,
|
|
241
|
+
...mistralOptions
|
|
242
|
+
} = config;
|
|
243
|
+
return withProviderSession(
|
|
244
|
+
mistral.metorialMistral,
|
|
245
|
+
{
|
|
246
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
247
|
+
},
|
|
248
|
+
async (session) => {
|
|
249
|
+
let tools = requestedTools ? session.tools.filter((t) => {
|
|
250
|
+
var _a;
|
|
251
|
+
return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
|
|
252
|
+
}) : session.tools;
|
|
253
|
+
let fixedTools = tools.map((tool) => {
|
|
254
|
+
var _a;
|
|
255
|
+
if ((_a = tool.function) == null ? void 0 : _a.parameters) {
|
|
256
|
+
let fixedParams = { ...tool.function.parameters };
|
|
257
|
+
fixedParams.additionalProperties = false;
|
|
258
|
+
if (fixedParams.properties) {
|
|
259
|
+
Object.values(fixedParams.properties).forEach((prop) => {
|
|
260
|
+
if (prop && typeof prop === "object" && prop.type === "object") {
|
|
261
|
+
prop.additionalProperties = false;
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
return {
|
|
266
|
+
...tool,
|
|
267
|
+
function: {
|
|
268
|
+
...tool.function,
|
|
269
|
+
parameters: fixedParams
|
|
270
|
+
}
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
return tool;
|
|
274
|
+
});
|
|
275
|
+
let messages = [
|
|
276
|
+
{ role: "user", content: message }
|
|
277
|
+
];
|
|
278
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
279
|
+
let response = await client.chat.complete({
|
|
280
|
+
model,
|
|
281
|
+
messages,
|
|
282
|
+
tools: fixedTools,
|
|
283
|
+
...mistralOptions
|
|
284
|
+
});
|
|
285
|
+
let choice = response.choices[0];
|
|
286
|
+
let toolCalls = choice.message.toolCalls;
|
|
287
|
+
if (!toolCalls || toolCalls.length === 0) {
|
|
288
|
+
return {
|
|
289
|
+
text: extractTextFromContent(choice.message.content),
|
|
290
|
+
steps: step + 1
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
let toolResponses = await session.callTools(toolCalls);
|
|
294
|
+
messages.push(
|
|
295
|
+
{ role: "assistant", toolCalls },
|
|
296
|
+
...toolResponses
|
|
297
|
+
);
|
|
298
|
+
}
|
|
299
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
300
|
+
}
|
|
301
|
+
);
|
|
302
|
+
};
|
|
303
|
+
var runWithXAI = async (config) => {
|
|
304
|
+
let {
|
|
305
|
+
message,
|
|
306
|
+
serverDeployments,
|
|
307
|
+
client,
|
|
308
|
+
model,
|
|
309
|
+
maxSteps = 25,
|
|
310
|
+
tools: requestedTools,
|
|
311
|
+
withProviderSession,
|
|
312
|
+
...xaiOptions
|
|
313
|
+
} = config;
|
|
314
|
+
return withProviderSession(
|
|
315
|
+
xai.metorialXai,
|
|
316
|
+
{
|
|
317
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
318
|
+
},
|
|
319
|
+
async (session) => {
|
|
320
|
+
let tools = requestedTools ? session.tools.filter((t) => {
|
|
321
|
+
var _a;
|
|
322
|
+
return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
|
|
323
|
+
}) : session.tools;
|
|
324
|
+
let uniqueTools = Array.from(
|
|
325
|
+
new Map(tools.map((t) => [t.function.name, t])).values()
|
|
326
|
+
);
|
|
327
|
+
let messages = [
|
|
328
|
+
{ role: "user", content: message }
|
|
329
|
+
];
|
|
330
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
331
|
+
let response = await client.chat.completions.create({
|
|
332
|
+
model,
|
|
333
|
+
messages,
|
|
334
|
+
tools: uniqueTools,
|
|
335
|
+
...xaiOptions
|
|
336
|
+
});
|
|
337
|
+
let choice = response.choices[0];
|
|
338
|
+
if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
|
|
339
|
+
return {
|
|
340
|
+
text: choice.message.content || "",
|
|
341
|
+
steps: step + 1
|
|
342
|
+
};
|
|
343
|
+
}
|
|
344
|
+
let toolResponses = await session.callTools(choice.message.tool_calls);
|
|
345
|
+
messages.push(
|
|
346
|
+
{ role: "assistant", tool_calls: choice.message.tool_calls },
|
|
347
|
+
...toolResponses
|
|
348
|
+
);
|
|
349
|
+
}
|
|
350
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
351
|
+
}
|
|
352
|
+
);
|
|
353
|
+
};
|
|
354
|
+
var runWithTogetherAI = async (config) => {
|
|
355
|
+
let {
|
|
356
|
+
message,
|
|
357
|
+
serverDeployments,
|
|
358
|
+
client,
|
|
359
|
+
model,
|
|
360
|
+
maxSteps = 25,
|
|
361
|
+
tools: requestedTools,
|
|
362
|
+
withProviderSession,
|
|
363
|
+
...togetheraiOptions
|
|
364
|
+
} = config;
|
|
365
|
+
return withProviderSession(
|
|
366
|
+
togetherai.metorialTogetherAi,
|
|
367
|
+
{
|
|
368
|
+
serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
|
|
369
|
+
},
|
|
370
|
+
async (session) => {
|
|
371
|
+
let tools = requestedTools ? session.tools.filter((t) => {
|
|
372
|
+
var _a;
|
|
373
|
+
return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
|
|
374
|
+
}) : session.tools;
|
|
375
|
+
let messages = [
|
|
376
|
+
{ role: "user", content: message }
|
|
377
|
+
];
|
|
378
|
+
for (let step = 0; step < maxSteps; step++) {
|
|
379
|
+
let response = await client.chat.completions.create({
|
|
380
|
+
model,
|
|
381
|
+
messages,
|
|
382
|
+
tools,
|
|
383
|
+
...togetheraiOptions
|
|
384
|
+
});
|
|
385
|
+
let choice = response.choices[0];
|
|
386
|
+
if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
|
|
387
|
+
return {
|
|
388
|
+
text: choice.message.content || "",
|
|
389
|
+
steps: step + 1
|
|
390
|
+
};
|
|
391
|
+
}
|
|
392
|
+
let toolResponses = await session.callTools(choice.message.tool_calls);
|
|
393
|
+
messages.push(
|
|
394
|
+
{ role: "assistant", tool_calls: choice.message.tool_calls },
|
|
395
|
+
...toolResponses
|
|
396
|
+
);
|
|
397
|
+
}
|
|
398
|
+
throw new Error(`Max steps (${maxSteps}) reached without final response`);
|
|
399
|
+
}
|
|
400
|
+
);
|
|
401
|
+
};
|
|
5
402
|
|
|
6
403
|
// src/metorial.ts
|
|
7
404
|
var Metorial = class {
|
|
@@ -20,6 +417,12 @@ var Metorial = class {
|
|
|
20
417
|
get sessions() {
|
|
21
418
|
return this.sdk.sessions;
|
|
22
419
|
}
|
|
420
|
+
get oauth() {
|
|
421
|
+
return {
|
|
422
|
+
...this.sdk.oauth,
|
|
423
|
+
waitForCompletion: this.waitForOAuthCompletion.bind(this)
|
|
424
|
+
};
|
|
425
|
+
}
|
|
23
426
|
get _config() {
|
|
24
427
|
return this.sdk._config;
|
|
25
428
|
}
|
|
@@ -62,6 +465,115 @@ var Metorial = class {
|
|
|
62
465
|
});
|
|
63
466
|
});
|
|
64
467
|
}
|
|
468
|
+
inferProvider(model) {
|
|
469
|
+
let modelLower = model.toLowerCase();
|
|
470
|
+
if (modelLower.startsWith("claude-")) {
|
|
471
|
+
return "anthropic";
|
|
472
|
+
}
|
|
473
|
+
if (modelLower.startsWith("gpt-") || modelLower.startsWith("o1-")) {
|
|
474
|
+
return "openai";
|
|
475
|
+
}
|
|
476
|
+
if (modelLower.includes("deepseek")) {
|
|
477
|
+
return "deepseek";
|
|
478
|
+
}
|
|
479
|
+
if (modelLower.startsWith("gemini-") || modelLower.includes("google")) {
|
|
480
|
+
return "google";
|
|
481
|
+
}
|
|
482
|
+
if (modelLower.startsWith("mistral-") || modelLower.includes("mistral")) {
|
|
483
|
+
return "mistral";
|
|
484
|
+
}
|
|
485
|
+
if (modelLower.startsWith("x-") || modelLower === "grok-beta") {
|
|
486
|
+
return "xai";
|
|
487
|
+
}
|
|
488
|
+
if (modelLower.includes("together") || modelLower.includes("llama") || modelLower.includes("mixtral") || modelLower.includes("qwen") || modelLower.includes("/")) {
|
|
489
|
+
return "togetherai";
|
|
490
|
+
}
|
|
491
|
+
throw new Error(`Unable to infer provider from model "${model}".`);
|
|
492
|
+
}
|
|
493
|
+
async waitForOAuthCompletion(sessions, options) {
|
|
494
|
+
var _a, _b;
|
|
495
|
+
let pollInterval = Math.max((_a = options == null ? void 0 : options.pollInterval) != null ? _a : 5e3, 2e3);
|
|
496
|
+
let timeout = (_b = options == null ? void 0 : options.timeout) != null ? _b : 6e5;
|
|
497
|
+
let startTime = Date.now();
|
|
498
|
+
if (sessions.length === 0) {
|
|
499
|
+
return;
|
|
500
|
+
}
|
|
501
|
+
while (true) {
|
|
502
|
+
if (Date.now() - startTime > timeout) {
|
|
503
|
+
throw new Error(`OAuth authentication timeout after ${timeout / 1e3} seconds`);
|
|
504
|
+
}
|
|
505
|
+
try {
|
|
506
|
+
let statuses = await Promise.all(
|
|
507
|
+
sessions.map((session) => this.oauth.sessions.get(session.id))
|
|
508
|
+
);
|
|
509
|
+
let allCompleted = statuses.every((status) => status.status === "completed");
|
|
510
|
+
if (allCompleted) {
|
|
511
|
+
return;
|
|
512
|
+
}
|
|
513
|
+
let failedSessions = statuses.filter((status) => status.status === "failed");
|
|
514
|
+
if (failedSessions.length > 0) {
|
|
515
|
+
throw new Error(
|
|
516
|
+
`OAuth authentication failed for ${failedSessions.length} session(s)`
|
|
517
|
+
);
|
|
518
|
+
}
|
|
519
|
+
await new Promise((resolve) => setTimeout(resolve, pollInterval));
|
|
520
|
+
} catch (error) {
|
|
521
|
+
if (error instanceof Error && (error.message.includes("OAuth authentication failed") || error.message.includes("OAuth authentication timeout"))) {
|
|
522
|
+
throw error;
|
|
523
|
+
}
|
|
524
|
+
await new Promise((resolve) => setTimeout(resolve, pollInterval));
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
async run(config) {
|
|
529
|
+
let provider = this.inferProvider(config.model);
|
|
530
|
+
switch (provider) {
|
|
531
|
+
case "openai":
|
|
532
|
+
return runWithOpenAI({
|
|
533
|
+
...config,
|
|
534
|
+
client: config.client,
|
|
535
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
536
|
+
});
|
|
537
|
+
case "anthropic":
|
|
538
|
+
return runWithAnthropic({
|
|
539
|
+
...config,
|
|
540
|
+
client: config.client,
|
|
541
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
542
|
+
});
|
|
543
|
+
case "deepseek":
|
|
544
|
+
return runWithDeepSeek({
|
|
545
|
+
...config,
|
|
546
|
+
client: config.client,
|
|
547
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
548
|
+
});
|
|
549
|
+
case "google":
|
|
550
|
+
return runWithGoogle({
|
|
551
|
+
...config,
|
|
552
|
+
client: config.client,
|
|
553
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
554
|
+
});
|
|
555
|
+
case "mistral":
|
|
556
|
+
return runWithMistral({
|
|
557
|
+
...config,
|
|
558
|
+
client: config.client,
|
|
559
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
560
|
+
});
|
|
561
|
+
case "xai":
|
|
562
|
+
return runWithXAI({
|
|
563
|
+
...config,
|
|
564
|
+
client: config.client,
|
|
565
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
566
|
+
});
|
|
567
|
+
case "togetherai":
|
|
568
|
+
return runWithTogetherAI({
|
|
569
|
+
...config,
|
|
570
|
+
client: config.client,
|
|
571
|
+
withProviderSession: this.withProviderSession.bind(this)
|
|
572
|
+
});
|
|
573
|
+
default:
|
|
574
|
+
throw new Error(`Unsupported provider: ${provider}`);
|
|
575
|
+
}
|
|
576
|
+
}
|
|
65
577
|
};
|
|
66
578
|
|
|
67
579
|
exports.Metorial = Metorial;
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/metorial.ts"],"names":[],"mappings":";AAAA,SAA0B,6BAA6B;AACvD;AAAA,EACE;AAAA,OAGK;AAEA,IAAM,WAAN,MAA0C;AAAA,EAG/C,YAAY,MAAmD;AAC7D,SAAK,MAAM,sBAAsB,IAAI;AAAA,EACvC;AAAA,EAEA,IAAI,WAAW;AACb,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAEA,IAAI,WAAW;AACb,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAEA,IAAI,MAAM;AACR,WAAO;AAAA,MACL,eAAe,CAAC,SAAiC,IAAI,mBAAmB,KAAK,KAAK,IAAI;AAAA,MACtF,aAAa,KAAK,YAAY,KAAK,IAAI;AAAA,MACvC,qBAAqB,KAAK,oBAAoB,KAAK,IAAI;AAAA,MACvD,kBAAkB,KAAK,oBAAoB,KAAK,IAAI;AAAA,IACtD;AAAA,EACF;AAAA,EAEA,MAAM,oBAAoB,MAAuD;AAC/E,QAAI,UAAU,IAAI,mBAAmB,KAAK,KAAK;AAAA,MAC7C,mBAAmB,CAAC,IAAI;AAAA,IAC1B,CAAC;AAED,QAAI,cAAc,MAAM,QAAQ,qBAAqB;AAErD,WAAO,MAAM,QAAQ,UAAU;AAAA,MAC7B,cAAc,YAAY,CAAC,EAAE;AAAA,IAC/B,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,YACJ,MACA,QACY;AACZ,QAAI,UAAU,IAAI,mBAAmB,KAAK,KAAK,IAAI;AACnD,QAAI;AACF,aAAO,MAAM,OAAO,OAAO;AAAA,IAC7B,UAAE;AACA,YAAM,QAAQ,MAAM;AAAA,IACtB;AAAA,EACF;AAAA,EAEA,MAAM,oBACJ,UACA,MACA,QAUY;AACZ,WAAO,KAAK,YAAY,MAAM,OAAM,YAAW;AAC7C,UAAI,eAAe,MAAM,SAAS,OAAO;AAEzC,aAAO,OAAO;AAAA,QACZ,GAAG;AAAA,QAEH;AAAA,QAEA,YAAY,QAAQ,WAAW,KAAK,OAAO;AAAA,QAC3C,iBAAiB,QAAQ,gBAAgB,KAAK,OAAO;AAAA,QACrD,WAAW,QAAQ,UAAU,KAAK,OAAO;AAAA,QACzC,sBAAsB,QAAQ,qBAAqB,KAAK,OAAO;AAAA,QAC/D,gBAAgB,QAAQ,eAAe,KAAK,OAAO;AAAA,MACrD,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF","sourcesContent":["import { MetorialCoreSDK, createMetorialCoreSDK } from '@metorial/core';\nimport {\n MetorialMcpSession,\n MetorialMcpSessionInit,\n MetorialMcpSessionInitServerDeployments\n} from '@metorial/mcp-session';\n\nexport class Metorial implements MetorialCoreSDK {\n private readonly sdk: MetorialCoreSDK;\n\n constructor(init: Parameters<typeof createMetorialCoreSDK>[0]) {\n this.sdk = createMetorialCoreSDK(init);\n }\n\n get instance() {\n return this.sdk.instance;\n }\n\n get secrets() {\n return this.sdk.secrets;\n }\n\n get servers() {\n return this.sdk.servers;\n }\n\n get sessions() {\n return this.sdk.sessions;\n }\n\n get _config() {\n return this.sdk._config;\n }\n\n get mcp() {\n return {\n createSession: (init: MetorialMcpSessionInit) => new MetorialMcpSession(this.sdk, init),\n withSession: this.withSession.bind(this),\n withProviderSession: this.withProviderSession.bind(this),\n createConnection: this.createMcpConnection.bind(this)\n };\n }\n\n async createMcpConnection(init: MetorialMcpSessionInitServerDeployments[number]) {\n let session = new MetorialMcpSession(this.sdk, {\n serverDeployments: [init]\n });\n\n let deployments = await session.getServerDeployments();\n\n return await session.getClient({\n deploymentId: deployments[0].id\n });\n }\n\n async withSession<T>(\n init: MetorialMcpSessionInit,\n action: (session: MetorialMcpSession) => Promise<T>\n ): Promise<T> {\n let session = new MetorialMcpSession(this.sdk, init);\n try {\n return await action(session);\n } finally {\n await session.close();\n }\n }\n\n async withProviderSession<P, T>(\n provider: (session: MetorialMcpSession) => Promise<P>,\n init: MetorialMcpSessionInit,\n action: (\n input: P & {\n session: MetorialMcpSession;\n getSession: MetorialMcpSession['getSession'];\n getCapabilities: MetorialMcpSession['getCapabilities'];\n getClient: MetorialMcpSession['getClient'];\n getServerDeployments: MetorialMcpSession['getServerDeployments'];\n getToolManager: MetorialMcpSession['getToolManager'];\n }\n ) => Promise<T>\n ): Promise<T> {\n return this.withSession(init, async session => {\n let providerData = await provider(session);\n\n return action({\n ...providerData,\n\n session,\n\n getSession: session.getSession.bind(session),\n getCapabilities: session.getCapabilities.bind(session),\n getClient: session.getClient.bind(session),\n getServerDeployments: session.getServerDeployments.bind(session),\n getToolManager: session.getToolManager.bind(session)\n });\n });\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/metorial.ts","../src/providers/openai.ts","../src/providers/anthropic.ts","../src/providers/deepseek.ts","../src/providers/google.ts","../src/providers/mistral.ts","../src/providers/xai.ts","../src/providers/togetherai.ts"],"names":[],"mappings":"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","sourcesContent":["import { MetorialCoreSDK, createMetorialCoreSDK } from '@metorial/core';\nimport {\n MetorialMcpSession,\n MetorialMcpSessionInit,\n MetorialMcpSessionInitServerDeployments\n} from '@metorial/mcp-session';\n\nimport type OpenAI from 'openai';\nimport type Anthropic from '@anthropic-ai/sdk';\nimport type { GoogleGenAI } from '@google/genai';\nimport type { Mistral } from '@mistralai/mistralai';\n\nimport { runWithOpenAI } from './providers/openai';\nimport { runWithAnthropic } from './providers/anthropic';\nimport { runWithDeepSeek } from './providers/deepseek';\nimport { runWithGoogle } from './providers/google';\nimport { runWithMistral } from './providers/mistral';\nimport { runWithXAI } from './providers/xai';\nimport { runWithTogetherAI } from './providers/togetherai';\n\nimport { RunResult } from './providers/types';\n\nexport type { RunResult } from './providers/types';\nexport type {\n MetorialMcpSession,\n MetorialMcpSessionInit,\n MetorialMcpSessionInitServerDeployments\n} from '@metorial/mcp-session';\n\nexport class Metorial implements MetorialCoreSDK {\n private readonly sdk: MetorialCoreSDK;\n\n constructor(init: Parameters<typeof createMetorialCoreSDK>[0]) {\n this.sdk = createMetorialCoreSDK(init);\n }\n\n get instance() {\n return this.sdk.instance;\n }\n\n get secrets() {\n return this.sdk.secrets;\n }\n\n get servers() {\n return this.sdk.servers;\n }\n\n get sessions() {\n return this.sdk.sessions;\n }\n\n get oauth(): typeof this.sdk.oauth & {\n waitForCompletion: (\n sessions: Array<{ id: string }>,\n options?: {\n pollInterval?: number;\n timeout?: number;\n }\n ) => Promise<void>;\n } {\n return {\n ...this.sdk.oauth,\n waitForCompletion: this.waitForOAuthCompletion.bind(this)\n };\n }\n\n get _config() {\n return this.sdk._config;\n }\n\n get mcp() {\n return {\n createSession: (init: MetorialMcpSessionInit) => new MetorialMcpSession(this.sdk, init),\n withSession: this.withSession.bind(this),\n withProviderSession: this.withProviderSession.bind(this),\n createConnection: this.createMcpConnection.bind(this)\n };\n }\n\n async createMcpConnection(init: MetorialMcpSessionInitServerDeployments[number]) {\n let session = new MetorialMcpSession(this.sdk, {\n serverDeployments: [init]\n });\n\n let deployments = await session.getServerDeployments();\n\n return await session.getClient({\n deploymentId: deployments[0].id\n });\n }\n\n async withSession<T>(\n init: MetorialMcpSessionInit,\n action: (session: MetorialMcpSession) => Promise<T>\n ): Promise<T> {\n let session = new MetorialMcpSession(this.sdk, init);\n try {\n return await action(session);\n } finally {\n await session.close();\n }\n }\n\n async withProviderSession<P, T>(\n provider: (session: MetorialMcpSession) => Promise<P>,\n init: MetorialMcpSessionInit,\n action: (\n input: P & {\n session: MetorialMcpSession;\n getSession: MetorialMcpSession['getSession'];\n getCapabilities: MetorialMcpSession['getCapabilities'];\n getClient: MetorialMcpSession['getClient'];\n getServerDeployments: MetorialMcpSession['getServerDeployments'];\n getToolManager: MetorialMcpSession['getToolManager'];\n }\n ) => Promise<T>\n ): Promise<T> {\n return this.withSession(init, async session => {\n let providerData = await provider(session);\n\n return action({\n ...providerData,\n session,\n getSession: session.getSession.bind(session),\n getCapabilities: session.getCapabilities.bind(session),\n getClient: session.getClient.bind(session),\n getServerDeployments: session.getServerDeployments.bind(session),\n getToolManager: session.getToolManager.bind(session)\n });\n });\n }\n\n private inferProvider(\n model: string\n ): 'openai' | 'anthropic' | 'deepseek' | 'google' | 'mistral' | 'xai' | 'togetherai' {\n let modelLower = model.toLowerCase();\n\n if (modelLower.startsWith('claude-')) {\n return 'anthropic';\n }\n\n if (modelLower.startsWith('gpt-') || modelLower.startsWith('o1-')) {\n return 'openai';\n }\n\n if (modelLower.includes('deepseek')) {\n return 'deepseek';\n }\n\n if (modelLower.startsWith('gemini-') || modelLower.includes('google')) {\n return 'google';\n }\n\n if (modelLower.startsWith('mistral-') || modelLower.includes('mistral')) {\n return 'mistral';\n }\n\n if (modelLower.startsWith('x-') || modelLower === 'grok-beta') {\n return 'xai';\n }\n\n if (\n modelLower.includes('together') ||\n modelLower.includes('llama') ||\n modelLower.includes('mixtral') ||\n modelLower.includes('qwen') ||\n modelLower.includes('/')\n ) {\n return 'togetherai';\n }\n\n throw new Error(`Unable to infer provider from model \"${model}\".`);\n }\n\n async waitForOAuthCompletion(\n sessions: Array<{ id: string }>,\n options?: {\n pollInterval?: number;\n timeout?: number;\n }\n ): Promise<void> {\n let pollInterval = Math.max(options?.pollInterval ?? 5000, 2000); // minimum 2 seconds\n let timeout = options?.timeout ?? 600000; // 10 minutes\n let startTime = Date.now();\n\n if (sessions.length === 0) {\n return;\n }\n\n while (true) {\n if (Date.now() - startTime > timeout) {\n throw new Error(`OAuth authentication timeout after ${timeout / 1000} seconds`);\n }\n\n try {\n let statuses = await Promise.all(\n sessions.map(session => this.oauth.sessions.get(session.id))\n );\n\n let allCompleted = statuses.every(status => status.status === 'completed');\n if (allCompleted) {\n return;\n }\n\n let failedSessions = statuses.filter(status => status.status === 'failed');\n if (failedSessions.length > 0) {\n throw new Error(\n `OAuth authentication failed for ${failedSessions.length} session(s)`\n );\n }\n\n await new Promise(resolve => setTimeout(resolve, pollInterval));\n } catch (error) {\n if (\n error instanceof Error &&\n (error.message.includes('OAuth authentication failed') ||\n error.message.includes('OAuth authentication timeout'))\n ) {\n throw error;\n }\n\n await new Promise(resolve => setTimeout(resolve, pollInterval));\n }\n }\n }\n\n async run(config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n model: string;\n maxSteps?: number;\n tools?: string[];\n [key: string]: any;\n }): Promise<RunResult> {\n let provider = this.inferProvider(config.model);\n\n switch (provider) {\n case 'openai':\n return runWithOpenAI({\n ...config,\n client: config.client as OpenAI,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'anthropic':\n return runWithAnthropic({\n ...config,\n client: config.client as Anthropic,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'deepseek':\n return runWithDeepSeek({\n ...config,\n client: config.client as OpenAI,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'google':\n return runWithGoogle({\n ...config,\n client: config.client as GoogleGenAI,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'mistral':\n return runWithMistral({\n ...config,\n client: config.client as Mistral,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'xai':\n return runWithXAI({\n ...config,\n client: config.client as OpenAI,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n case 'togetherai':\n return runWithTogetherAI({\n ...config,\n client: config.client as OpenAI,\n withProviderSession: this.withProviderSession.bind(this)\n });\n\n default:\n throw new Error(`Unsupported provider: ${provider}`);\n }\n }\n}\n","import type OpenAI from 'openai';\nimport { metorialOpenAI } from '@metorial/openai';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet runWithOpenAI = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: OpenAI;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...openaiOptions \n } = config;\n\n return withProviderSession(\n metorialOpenAI.chatCompletions,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.name))\n : session.tools;\n\n let messages: OpenAI.Chat.Completions.ChatCompletionMessageParam[] = [\n { role: 'user', content: message }\n ];\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.chat.completions.create({\n model,\n messages,\n tools,\n ...openaiOptions\n });\n\n let choice = response.choices[0];\n \n if (!choice.message.tool_calls) {\n return {\n text: choice.message.content || '',\n steps: step + 1\n };\n }\n\n let toolResponses = await session.callTools(choice.message.tool_calls);\n\n messages.push(\n { role: 'assistant', tool_calls: choice.message.tool_calls },\n ...toolResponses\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithOpenAI };","import type Anthropic from '@anthropic-ai/sdk';\nimport { metorialAnthropic } from '@metorial/anthropic';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\ninterface ToolResultBlock {\n type: 'tool_result';\n tool_use_id: string;\n content: string;\n}\n\ninterface ToolResponseMessage {\n role: 'user';\n content: ToolResultBlock[];\n}\n\nlet runWithAnthropic = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: Anthropic;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n max_tokens?: number;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n max_tokens = 4096,\n ...anthropicOptions \n } = config;\n\n return withProviderSession(\n metorialAnthropic,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools: Anthropic.Tool[] = requestedTools\n ? (session.tools as Anthropic.Tool[]).filter(t => requestedTools.includes(t.name))\n : session.tools as Anthropic.Tool[];\n\n let messages: Anthropic.Messages.MessageParam[] = [\n { role: 'user', content: message }\n ];\n\n let uniqueTools = Array.from(new Map(tools.map(t => [t.name, t])).values());\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.messages.create({\n model,\n max_tokens,\n messages,\n tools: uniqueTools,\n ...anthropicOptions\n });\n\n if (response.stop_reason !== 'tool_use') {\n let textContent = response.content.find(\n (block): block is Anthropic.Messages.TextBlock => block.type === 'text'\n );\n return {\n text: textContent?.text || '',\n steps: step + 1\n };\n }\n\n let toolUseBlocks = response.content.filter(\n (block): block is Anthropic.Messages.ToolUseBlock => block.type === 'tool_use'\n );\n let toolResponse = await session.callTools(toolUseBlocks) as ToolResponseMessage;\n\n let toolResponseMessage: Anthropic.Messages.MessageParam = {\n role: 'user',\n content: toolResponse.content.map(block => ({\n type: 'tool_result' as const,\n tool_use_id: block.tool_use_id,\n content: block.content\n } as Anthropic.Messages.ToolResultBlockParam))\n };\n\n messages.push(\n { role: 'assistant', content: response.content },\n toolResponseMessage\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithAnthropic };","import type OpenAI from 'openai';\nimport { metorialDeepseek } from '@metorial/deepseek';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet runWithDeepSeek = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: OpenAI; // DeepSeek uses OpenAI-compatible client\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...deepseekOptions \n } = config;\n\n return withProviderSession(\n metorialDeepseek,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.function?.name || t.name))\n : session.tools;\n\n let uniqueTools = Array.from(\n new Map(tools.map((t: any) => [t.function?.name || t.name, t])).values()\n );\n\n let messages: OpenAI.Chat.Completions.ChatCompletionMessageParam[] = [\n { role: 'user', content: message }\n ];\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.chat.completions.create({\n model,\n messages,\n tools: uniqueTools,\n ...deepseekOptions\n });\n\n let choice = response.choices[0];\n \n if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {\n return {\n text: choice.message.content || '',\n steps: step + 1\n };\n }\n\n let toolResponses = await session.callTools(choice.message.tool_calls);\n\n messages.push(\n { role: 'assistant', tool_calls: choice.message.tool_calls },\n ...toolResponses\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithDeepSeek };","import type { GoogleGenAI } from '@google/genai';\nimport { metorialGoogle } from '@metorial/google';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet runWithGoogle = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: GoogleGenAI;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...googleOptions \n } = config;\n\n return withProviderSession(\n metorialGoogle,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.name))\n : session.tools;\n\n let response = await client.models.generateContent({\n model,\n contents: [\n {\n role: 'user',\n parts: [{ text: message }]\n }\n ],\n config: {\n tools,\n ...googleOptions\n }\n });\n\n let text = response.candidates?.[0]?.content?.parts?.[0]?.text;\n \n let functionCalls = response.candidates?.[0]?.content?.parts\n ?.filter((part: any) => part.functionCall)\n .map((part: any) => part.functionCall);\n\n if (functionCalls && functionCalls.length > 0) {\n let toolResponses = await session.callTools(functionCalls);\n \n return {\n text: text || '',\n toolResponses: toolResponses as any,\n steps: 1\n };\n }\n\n return {\n text: text || '',\n steps: 1\n };\n }\n );\n}\n\nexport { runWithGoogle };","import type { Mistral } from '@mistralai/mistralai';\nimport { metorialMistral } from '@metorial/mistral';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet extractTextFromContent = (content: unknown): string => {\n if (typeof content === 'string') {\n return content;\n }\n \n if (Array.isArray(content)) {\n return content\n .filter((chunk: any) => chunk && typeof chunk === 'object')\n .map((chunk: any) => chunk.text || chunk.content || JSON.stringify(chunk))\n .join('');\n }\n \n return '';\n}\n\nlet runWithMistral = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: Mistral;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...mistralOptions \n } = config;\n\n return withProviderSession(\n metorialMistral,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.function?.name || t.name))\n : session.tools;\n\n // Fix tools for Mistral compatibility: add additionalProperties: false\n let fixedTools = tools.map((tool: any) => {\n if (tool.function?.parameters) {\n let fixedParams = { ...tool.function.parameters };\n fixedParams.additionalProperties = false;\n\n // Also fix nested objects\n if (fixedParams.properties) {\n Object.values(fixedParams.properties).forEach((prop: any) => {\n if (prop && typeof prop === 'object' && prop.type === 'object') {\n prop.additionalProperties = false;\n }\n });\n }\n\n return {\n ...tool,\n function: {\n ...tool.function,\n parameters: fixedParams\n }\n };\n }\n return tool;\n });\n\n let messages: any[] = [\n { role: 'user', content: message }\n ];\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.chat.complete({\n model,\n messages,\n tools: fixedTools,\n ...mistralOptions\n });\n\n let choice = response.choices[0];\n let toolCalls = choice.message.toolCalls;\n \n if (!toolCalls || toolCalls.length === 0) {\n return {\n text: extractTextFromContent(choice.message.content),\n steps: step + 1\n };\n }\n\n let toolResponses = await session.callTools(toolCalls);\n\n messages.push(\n { role: 'assistant', toolCalls },\n ...toolResponses\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithMistral };","import type OpenAI from 'openai';\nimport { metorialXai } from '@metorial/xai';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet runWithXAI = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: OpenAI;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...xaiOptions \n } = config;\n\n return withProviderSession(\n metorialXai,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.function?.name || t.name))\n : session.tools;\n\n let uniqueTools = Array.from(\n new Map(tools.map((t: any) => [t.function.name, t])).values()\n );\n\n let messages: OpenAI.Chat.Completions.ChatCompletionMessageParam[] = [\n { role: 'user', content: message }\n ];\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.chat.completions.create({\n model,\n messages,\n tools: uniqueTools,\n ...xaiOptions\n });\n\n let choice = response.choices[0];\n \n if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {\n return {\n text: choice.message.content || '',\n steps: step + 1\n };\n }\n\n let toolResponses = await session.callTools(choice.message.tool_calls);\n\n messages.push(\n { role: 'assistant', tool_calls: choice.message.tool_calls },\n ...toolResponses\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithXAI };","import type OpenAI from 'openai';\nimport { metorialTogetherAi } from '@metorial/togetherai';\nimport type { MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';\nimport type { WithProviderSessionFunction, RunResult } from './types';\n\nlet runWithTogetherAI = async (config: {\n message: string;\n serverDeployments: string | MetorialMcpSessionInitServerDeployments;\n client: OpenAI;\n model: string;\n maxSteps?: number;\n tools?: string[];\n withProviderSession: WithProviderSessionFunction;\n [key: string]: any;\n}): Promise<RunResult> => {\n let { \n message, \n serverDeployments, \n client, \n model, \n maxSteps = 25, \n tools: requestedTools,\n withProviderSession,\n ...togetheraiOptions \n } = config;\n\n return withProviderSession(\n metorialTogetherAi,\n {\n serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]\n },\n async session => {\n let tools = requestedTools\n ? session.tools.filter((t: any) => requestedTools.includes(t.function?.name || t.name))\n : session.tools;\n\n let messages: OpenAI.Chat.Completions.ChatCompletionMessageParam[] = [\n { role: 'user', content: message }\n ];\n\n for (let step = 0; step < maxSteps; step++) {\n let response = await client.chat.completions.create({\n model,\n messages,\n tools,\n ...togetheraiOptions\n });\n\n let choice = response.choices[0];\n \n if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {\n return {\n text: choice.message.content || '',\n steps: step + 1\n };\n }\n\n let toolResponses = await session.callTools(choice.message.tool_calls);\n\n messages.push(\n { role: 'assistant', tool_calls: choice.message.tool_calls },\n ...toolResponses\n );\n }\n\n throw new Error(`Max steps (${maxSteps}) reached without final response`);\n }\n );\n}\n\nexport { runWithTogetherAI };"]}
|