@metorial/sdk 1.0.0-rc.6 → 1.0.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.d.ts CHANGED
@@ -1,9 +1,16 @@
1
1
  import * as _metorial_mcp_session from '@metorial/mcp-session';
2
2
  import { MetorialMcpSessionInit, MetorialMcpSession, MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';
3
+ export { MetorialMcpSession, MetorialMcpSessionInit, MetorialMcpSessionInitServerDeployments } from '@metorial/mcp-session';
3
4
  import * as _metorial_generated from '@metorial/generated';
4
5
  import { MetorialCoreSDK, createMetorialCoreSDK } from '@metorial/core';
5
6
  export * from '@metorial/core';
6
7
 
8
+ interface RunResult {
9
+ text: string;
10
+ steps: number;
11
+ toolResponses?: any;
12
+ }
13
+
7
14
  declare class Metorial implements MetorialCoreSDK {
8
15
  private readonly sdk;
9
16
  constructor(init: Parameters<typeof createMetorialCoreSDK>[0]);
@@ -22,6 +29,14 @@ declare class Metorial implements MetorialCoreSDK {
22
29
  messages: _metorial_generated.MetorialSessionsMessagesEndpoint;
23
30
  connections: _metorial_generated.MetorialSessionsConnectionsEndpoint;
24
31
  };
32
+ get oauth(): typeof this$1.sdk.oauth & {
33
+ waitForCompletion: (sessions: Array<{
34
+ id: string;
35
+ }>, options?: {
36
+ pollInterval?: number;
37
+ timeout?: number;
38
+ }) => Promise<void>;
39
+ };
25
40
  get _config(): {
26
41
  apiVersion: "2025-01-01-pulsar";
27
42
  apiKey: `${"metorial_uk_" | "metorial_mk_" | "metorial_sk_" | "metorial_ak_" | "metorial_pk_"}${string}` | string;
@@ -54,6 +69,21 @@ declare class Metorial implements MetorialCoreSDK {
54
69
  getServerDeployments: MetorialMcpSession['getServerDeployments'];
55
70
  getToolManager: MetorialMcpSession['getToolManager'];
56
71
  }) => Promise<T>): Promise<T>;
72
+ private inferProvider;
73
+ waitForOAuthCompletion(sessions: Array<{
74
+ id: string;
75
+ }>, options?: {
76
+ pollInterval?: number;
77
+ timeout?: number;
78
+ }): Promise<void>;
79
+ run(config: {
80
+ message: string;
81
+ serverDeployments: string | MetorialMcpSessionInitServerDeployments;
82
+ model: string;
83
+ maxSteps?: number;
84
+ tools?: string[];
85
+ [key: string]: any;
86
+ }): Promise<RunResult>;
57
87
  }
58
88
 
59
- export { Metorial };
89
+ export { Metorial, type RunResult };
package/dist/index.js CHANGED
@@ -1,5 +1,402 @@
1
1
  import { createMetorialCoreSDK } from '@metorial/core';
2
2
  import { MetorialMcpSession } from '@metorial/mcp-session';
3
+ import { metorialOpenAI } from '@metorial/openai';
4
+ import { metorialAnthropic } from '@metorial/anthropic';
5
+ import { metorialDeepseek } from '@metorial/deepseek';
6
+ import { metorialGoogle } from '@metorial/google';
7
+ import { metorialMistral } from '@metorial/mistral';
8
+ import { metorialXai } from '@metorial/xai';
9
+ import { metorialTogetherAi } from '@metorial/togetherai';
10
+
11
+ // src/metorial.ts
12
+ var runWithOpenAI = async (config) => {
13
+ let {
14
+ message,
15
+ serverDeployments,
16
+ client,
17
+ model,
18
+ maxSteps = 25,
19
+ tools: requestedTools,
20
+ withProviderSession,
21
+ ...openaiOptions
22
+ } = config;
23
+ return withProviderSession(
24
+ metorialOpenAI.chatCompletions,
25
+ {
26
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
27
+ },
28
+ async (session) => {
29
+ let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
30
+ let messages = [
31
+ { role: "user", content: message }
32
+ ];
33
+ for (let step = 0; step < maxSteps; step++) {
34
+ let response = await client.chat.completions.create({
35
+ model,
36
+ messages,
37
+ tools,
38
+ ...openaiOptions
39
+ });
40
+ let choice = response.choices[0];
41
+ if (!choice.message.tool_calls) {
42
+ return {
43
+ text: choice.message.content || "",
44
+ steps: step + 1
45
+ };
46
+ }
47
+ let toolResponses = await session.callTools(choice.message.tool_calls);
48
+ messages.push(
49
+ { role: "assistant", tool_calls: choice.message.tool_calls },
50
+ ...toolResponses
51
+ );
52
+ }
53
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
54
+ }
55
+ );
56
+ };
57
+ var runWithAnthropic = async (config) => {
58
+ let {
59
+ message,
60
+ serverDeployments,
61
+ client,
62
+ model,
63
+ maxSteps = 25,
64
+ tools: requestedTools,
65
+ withProviderSession,
66
+ max_tokens = 4096,
67
+ ...anthropicOptions
68
+ } = config;
69
+ return withProviderSession(
70
+ metorialAnthropic,
71
+ {
72
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
73
+ },
74
+ async (session) => {
75
+ let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
76
+ let messages = [
77
+ { role: "user", content: message }
78
+ ];
79
+ let uniqueTools = Array.from(new Map(tools.map((t) => [t.name, t])).values());
80
+ for (let step = 0; step < maxSteps; step++) {
81
+ let response = await client.messages.create({
82
+ model,
83
+ max_tokens,
84
+ messages,
85
+ tools: uniqueTools,
86
+ ...anthropicOptions
87
+ });
88
+ if (response.stop_reason !== "tool_use") {
89
+ let textContent = response.content.find(
90
+ (block) => block.type === "text"
91
+ );
92
+ return {
93
+ text: (textContent == null ? void 0 : textContent.text) || "",
94
+ steps: step + 1
95
+ };
96
+ }
97
+ let toolUseBlocks = response.content.filter(
98
+ (block) => block.type === "tool_use"
99
+ );
100
+ let toolResponse = await session.callTools(toolUseBlocks);
101
+ let toolResponseMessage = {
102
+ role: "user",
103
+ content: toolResponse.content.map((block) => ({
104
+ type: "tool_result",
105
+ tool_use_id: block.tool_use_id,
106
+ content: block.content
107
+ }))
108
+ };
109
+ messages.push(
110
+ { role: "assistant", content: response.content },
111
+ toolResponseMessage
112
+ );
113
+ }
114
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
115
+ }
116
+ );
117
+ };
118
+ var runWithDeepSeek = async (config) => {
119
+ let {
120
+ message,
121
+ serverDeployments,
122
+ client,
123
+ model,
124
+ maxSteps = 25,
125
+ tools: requestedTools,
126
+ withProviderSession,
127
+ ...deepseekOptions
128
+ } = config;
129
+ return withProviderSession(
130
+ metorialDeepseek,
131
+ {
132
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
133
+ },
134
+ async (session) => {
135
+ let tools = requestedTools ? session.tools.filter((t) => {
136
+ var _a;
137
+ return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
138
+ }) : session.tools;
139
+ let uniqueTools = Array.from(
140
+ new Map(tools.map((t) => {
141
+ var _a;
142
+ return [((_a = t.function) == null ? void 0 : _a.name) || t.name, t];
143
+ })).values()
144
+ );
145
+ let messages = [
146
+ { role: "user", content: message }
147
+ ];
148
+ for (let step = 0; step < maxSteps; step++) {
149
+ let response = await client.chat.completions.create({
150
+ model,
151
+ messages,
152
+ tools: uniqueTools,
153
+ ...deepseekOptions
154
+ });
155
+ let choice = response.choices[0];
156
+ if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
157
+ return {
158
+ text: choice.message.content || "",
159
+ steps: step + 1
160
+ };
161
+ }
162
+ let toolResponses = await session.callTools(choice.message.tool_calls);
163
+ messages.push(
164
+ { role: "assistant", tool_calls: choice.message.tool_calls },
165
+ ...toolResponses
166
+ );
167
+ }
168
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
169
+ }
170
+ );
171
+ };
172
+ var runWithGoogle = async (config) => {
173
+ let {
174
+ message,
175
+ serverDeployments,
176
+ client,
177
+ model,
178
+ maxSteps = 25,
179
+ tools: requestedTools,
180
+ withProviderSession,
181
+ ...googleOptions
182
+ } = config;
183
+ return withProviderSession(
184
+ metorialGoogle,
185
+ {
186
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
187
+ },
188
+ async (session) => {
189
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i;
190
+ let tools = requestedTools ? session.tools.filter((t) => requestedTools.includes(t.name)) : session.tools;
191
+ let response = await client.models.generateContent({
192
+ model,
193
+ contents: [
194
+ {
195
+ role: "user",
196
+ parts: [{ text: message }]
197
+ }
198
+ ],
199
+ config: {
200
+ tools,
201
+ ...googleOptions
202
+ }
203
+ });
204
+ 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;
205
+ 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);
206
+ if (functionCalls && functionCalls.length > 0) {
207
+ let toolResponses = await session.callTools(functionCalls);
208
+ return {
209
+ text: text || "",
210
+ toolResponses,
211
+ steps: 1
212
+ };
213
+ }
214
+ return {
215
+ text: text || "",
216
+ steps: 1
217
+ };
218
+ }
219
+ );
220
+ };
221
+ var extractTextFromContent = (content) => {
222
+ if (typeof content === "string") {
223
+ return content;
224
+ }
225
+ if (Array.isArray(content)) {
226
+ return content.filter((chunk) => chunk && typeof chunk === "object").map((chunk) => chunk.text || chunk.content || JSON.stringify(chunk)).join("");
227
+ }
228
+ return "";
229
+ };
230
+ var runWithMistral = async (config) => {
231
+ let {
232
+ message,
233
+ serverDeployments,
234
+ client,
235
+ model,
236
+ maxSteps = 25,
237
+ tools: requestedTools,
238
+ withProviderSession,
239
+ ...mistralOptions
240
+ } = config;
241
+ return withProviderSession(
242
+ metorialMistral,
243
+ {
244
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
245
+ },
246
+ async (session) => {
247
+ let tools = requestedTools ? session.tools.filter((t) => {
248
+ var _a;
249
+ return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
250
+ }) : session.tools;
251
+ let fixedTools = tools.map((tool) => {
252
+ var _a;
253
+ if ((_a = tool.function) == null ? void 0 : _a.parameters) {
254
+ let fixedParams = { ...tool.function.parameters };
255
+ fixedParams.additionalProperties = false;
256
+ if (fixedParams.properties) {
257
+ Object.values(fixedParams.properties).forEach((prop) => {
258
+ if (prop && typeof prop === "object" && prop.type === "object") {
259
+ prop.additionalProperties = false;
260
+ }
261
+ });
262
+ }
263
+ return {
264
+ ...tool,
265
+ function: {
266
+ ...tool.function,
267
+ parameters: fixedParams
268
+ }
269
+ };
270
+ }
271
+ return tool;
272
+ });
273
+ let messages = [
274
+ { role: "user", content: message }
275
+ ];
276
+ for (let step = 0; step < maxSteps; step++) {
277
+ let response = await client.chat.complete({
278
+ model,
279
+ messages,
280
+ tools: fixedTools,
281
+ ...mistralOptions
282
+ });
283
+ let choice = response.choices[0];
284
+ let toolCalls = choice.message.toolCalls;
285
+ if (!toolCalls || toolCalls.length === 0) {
286
+ return {
287
+ text: extractTextFromContent(choice.message.content),
288
+ steps: step + 1
289
+ };
290
+ }
291
+ let toolResponses = await session.callTools(toolCalls);
292
+ messages.push(
293
+ { role: "assistant", toolCalls },
294
+ ...toolResponses
295
+ );
296
+ }
297
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
298
+ }
299
+ );
300
+ };
301
+ var runWithXAI = async (config) => {
302
+ let {
303
+ message,
304
+ serverDeployments,
305
+ client,
306
+ model,
307
+ maxSteps = 25,
308
+ tools: requestedTools,
309
+ withProviderSession,
310
+ ...xaiOptions
311
+ } = config;
312
+ return withProviderSession(
313
+ metorialXai,
314
+ {
315
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
316
+ },
317
+ async (session) => {
318
+ let tools = requestedTools ? session.tools.filter((t) => {
319
+ var _a;
320
+ return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
321
+ }) : session.tools;
322
+ let uniqueTools = Array.from(
323
+ new Map(tools.map((t) => [t.function.name, t])).values()
324
+ );
325
+ let messages = [
326
+ { role: "user", content: message }
327
+ ];
328
+ for (let step = 0; step < maxSteps; step++) {
329
+ let response = await client.chat.completions.create({
330
+ model,
331
+ messages,
332
+ tools: uniqueTools,
333
+ ...xaiOptions
334
+ });
335
+ let choice = response.choices[0];
336
+ if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
337
+ return {
338
+ text: choice.message.content || "",
339
+ steps: step + 1
340
+ };
341
+ }
342
+ let toolResponses = await session.callTools(choice.message.tool_calls);
343
+ messages.push(
344
+ { role: "assistant", tool_calls: choice.message.tool_calls },
345
+ ...toolResponses
346
+ );
347
+ }
348
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
349
+ }
350
+ );
351
+ };
352
+ var runWithTogetherAI = async (config) => {
353
+ let {
354
+ message,
355
+ serverDeployments,
356
+ client,
357
+ model,
358
+ maxSteps = 25,
359
+ tools: requestedTools,
360
+ withProviderSession,
361
+ ...togetheraiOptions
362
+ } = config;
363
+ return withProviderSession(
364
+ metorialTogetherAi,
365
+ {
366
+ serverDeployments: Array.isArray(serverDeployments) ? serverDeployments : [serverDeployments]
367
+ },
368
+ async (session) => {
369
+ let tools = requestedTools ? session.tools.filter((t) => {
370
+ var _a;
371
+ return requestedTools.includes(((_a = t.function) == null ? void 0 : _a.name) || t.name);
372
+ }) : session.tools;
373
+ let messages = [
374
+ { role: "user", content: message }
375
+ ];
376
+ for (let step = 0; step < maxSteps; step++) {
377
+ let response = await client.chat.completions.create({
378
+ model,
379
+ messages,
380
+ tools,
381
+ ...togetheraiOptions
382
+ });
383
+ let choice = response.choices[0];
384
+ if (!choice.message.tool_calls || choice.message.tool_calls.length === 0) {
385
+ return {
386
+ text: choice.message.content || "",
387
+ steps: step + 1
388
+ };
389
+ }
390
+ let toolResponses = await session.callTools(choice.message.tool_calls);
391
+ messages.push(
392
+ { role: "assistant", tool_calls: choice.message.tool_calls },
393
+ ...toolResponses
394
+ );
395
+ }
396
+ throw new Error(`Max steps (${maxSteps}) reached without final response`);
397
+ }
398
+ );
399
+ };
3
400
 
4
401
  // src/metorial.ts
5
402
  var Metorial = class {
@@ -18,6 +415,12 @@ var Metorial = class {
18
415
  get sessions() {
19
416
  return this.sdk.sessions;
20
417
  }
418
+ get oauth() {
419
+ return {
420
+ ...this.sdk.oauth,
421
+ waitForCompletion: this.waitForOAuthCompletion.bind(this)
422
+ };
423
+ }
21
424
  get _config() {
22
425
  return this.sdk._config;
23
426
  }
@@ -60,6 +463,115 @@ var Metorial = class {
60
463
  });
61
464
  });
62
465
  }
466
+ inferProvider(model) {
467
+ let modelLower = model.toLowerCase();
468
+ if (modelLower.startsWith("claude-")) {
469
+ return "anthropic";
470
+ }
471
+ if (modelLower.startsWith("gpt-") || modelLower.startsWith("o1-")) {
472
+ return "openai";
473
+ }
474
+ if (modelLower.includes("deepseek")) {
475
+ return "deepseek";
476
+ }
477
+ if (modelLower.startsWith("gemini-") || modelLower.includes("google")) {
478
+ return "google";
479
+ }
480
+ if (modelLower.startsWith("mistral-") || modelLower.includes("mistral")) {
481
+ return "mistral";
482
+ }
483
+ if (modelLower.startsWith("x-") || modelLower === "grok-beta") {
484
+ return "xai";
485
+ }
486
+ if (modelLower.includes("together") || modelLower.includes("llama") || modelLower.includes("mixtral") || modelLower.includes("qwen") || modelLower.includes("/")) {
487
+ return "togetherai";
488
+ }
489
+ throw new Error(`Unable to infer provider from model "${model}".`);
490
+ }
491
+ async waitForOAuthCompletion(sessions, options) {
492
+ var _a, _b;
493
+ let pollInterval = Math.max((_a = options == null ? void 0 : options.pollInterval) != null ? _a : 5e3, 2e3);
494
+ let timeout = (_b = options == null ? void 0 : options.timeout) != null ? _b : 6e5;
495
+ let startTime = Date.now();
496
+ if (sessions.length === 0) {
497
+ return;
498
+ }
499
+ while (true) {
500
+ if (Date.now() - startTime > timeout) {
501
+ throw new Error(`OAuth authentication timeout after ${timeout / 1e3} seconds`);
502
+ }
503
+ try {
504
+ let statuses = await Promise.all(
505
+ sessions.map((session) => this.oauth.sessions.get(session.id))
506
+ );
507
+ let allCompleted = statuses.every((status) => status.status === "completed");
508
+ if (allCompleted) {
509
+ return;
510
+ }
511
+ let failedSessions = statuses.filter((status) => status.status === "failed");
512
+ if (failedSessions.length > 0) {
513
+ throw new Error(
514
+ `OAuth authentication failed for ${failedSessions.length} session(s)`
515
+ );
516
+ }
517
+ await new Promise((resolve) => setTimeout(resolve, pollInterval));
518
+ } catch (error) {
519
+ if (error instanceof Error && (error.message.includes("OAuth authentication failed") || error.message.includes("OAuth authentication timeout"))) {
520
+ throw error;
521
+ }
522
+ await new Promise((resolve) => setTimeout(resolve, pollInterval));
523
+ }
524
+ }
525
+ }
526
+ async run(config) {
527
+ let provider = this.inferProvider(config.model);
528
+ switch (provider) {
529
+ case "openai":
530
+ return runWithOpenAI({
531
+ ...config,
532
+ client: config.client,
533
+ withProviderSession: this.withProviderSession.bind(this)
534
+ });
535
+ case "anthropic":
536
+ return runWithAnthropic({
537
+ ...config,
538
+ client: config.client,
539
+ withProviderSession: this.withProviderSession.bind(this)
540
+ });
541
+ case "deepseek":
542
+ return runWithDeepSeek({
543
+ ...config,
544
+ client: config.client,
545
+ withProviderSession: this.withProviderSession.bind(this)
546
+ });
547
+ case "google":
548
+ return runWithGoogle({
549
+ ...config,
550
+ client: config.client,
551
+ withProviderSession: this.withProviderSession.bind(this)
552
+ });
553
+ case "mistral":
554
+ return runWithMistral({
555
+ ...config,
556
+ client: config.client,
557
+ withProviderSession: this.withProviderSession.bind(this)
558
+ });
559
+ case "xai":
560
+ return runWithXAI({
561
+ ...config,
562
+ client: config.client,
563
+ withProviderSession: this.withProviderSession.bind(this)
564
+ });
565
+ case "togetherai":
566
+ return runWithTogetherAI({
567
+ ...config,
568
+ client: config.client,
569
+ withProviderSession: this.withProviderSession.bind(this)
570
+ });
571
+ default:
572
+ throw new Error(`Unsupported provider: ${provider}`);
573
+ }
574
+ }
63
575
  };
64
576
 
65
577
  export { Metorial };
package/dist/index.js.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 };"]}