@metorial/sdk 1.1.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -452,6 +452,9 @@ var Metorial = class {
452
452
  }
453
453
  }
454
454
  async withProviderSession(provider, init, action) {
455
+ if (init.streaming) {
456
+ return this.withStreamingSession(provider, init, action);
457
+ }
455
458
  return this.withSession(init, async (session) => {
456
459
  let providerData = await provider(session);
457
460
  return action({
@@ -465,6 +468,40 @@ var Metorial = class {
465
468
  });
466
469
  });
467
470
  }
471
+ async withStreamingSession(provider, init, action) {
472
+ let session = new mcpSession.MetorialMcpSession(this.sdk, init);
473
+ let sessionClosed = false;
474
+ const closeSession = async () => {
475
+ if (!sessionClosed) {
476
+ sessionClosed = true;
477
+ console.log("[Metorial] Closing streaming session");
478
+ await session.close();
479
+ }
480
+ };
481
+ try {
482
+ let providerData = await provider(session);
483
+ let result = await action({
484
+ ...providerData,
485
+ session,
486
+ getSession: session.getSession.bind(session),
487
+ getCapabilities: session.getCapabilities.bind(session),
488
+ getClient: session.getClient.bind(session),
489
+ getServerDeployments: session.getServerDeployments.bind(session),
490
+ getToolManager: session.getToolManager.bind(session),
491
+ closeSession
492
+ });
493
+ setTimeout(async () => {
494
+ if (!sessionClosed) {
495
+ console.log("[Metorial] Streaming timeout reached - auto-closing session");
496
+ await closeSession();
497
+ }
498
+ }, 6e4);
499
+ return result;
500
+ } catch (error) {
501
+ await closeSession();
502
+ throw error;
503
+ }
504
+ }
468
505
  inferProvider(model) {
469
506
  let modelLower = model.toLowerCase();
470
507
  if (modelLower.startsWith("claude-")) {
@@ -1 +1 @@
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 };"]}
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 & { streaming?: boolean },\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 if (init.streaming) {\n return this.withStreamingSession(provider, init, action);\n }\n\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 async withStreamingSession<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 closeSession: () => Promise<void>;\n }\n ) => Promise<T>\n ): Promise<T> {\n let session = new MetorialMcpSession(this.sdk, init);\n let sessionClosed = false;\n\n const closeSession = async () => {\n if (!sessionClosed) {\n sessionClosed = true;\n console.log('[Metorial] Closing streaming session');\n await session.close();\n }\n };\n\n try {\n let providerData = await provider(session);\n\n let result = await 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 closeSession\n });\n\n setTimeout(async () => {\n if (!sessionClosed) {\n console.log('[Metorial] Streaming timeout reached - auto-closing session');\n await closeSession();\n }\n }, 60000); // 1 minute timeout\n\n return result;\n } catch (error) {\n await closeSession();\n throw error;\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 };"]}
package/dist/index.d.cts CHANGED
@@ -49,7 +49,9 @@ declare class Metorial implements MetorialCoreSDK {
49
49
  get mcp(): {
50
50
  createSession: (init: MetorialMcpSessionInit) => MetorialMcpSession;
51
51
  withSession: <T>(init: MetorialMcpSessionInit, action: (session: MetorialMcpSession) => Promise<T>) => Promise<T>;
52
- withProviderSession: <P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit, action: (input: P & {
52
+ withProviderSession: <P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit & {
53
+ streaming?: boolean;
54
+ }, action: (input: P & {
53
55
  session: MetorialMcpSession;
54
56
  getSession: MetorialMcpSession["getSession"];
55
57
  getCapabilities: MetorialMcpSession["getCapabilities"];
@@ -61,7 +63,9 @@ declare class Metorial implements MetorialCoreSDK {
61
63
  };
62
64
  createMcpConnection(init: MetorialMcpSessionInitServerDeployments[number]): Promise<_metorial_mcp_session.MetorialMcpClient>;
63
65
  withSession<T>(init: MetorialMcpSessionInit, action: (session: MetorialMcpSession) => Promise<T>): Promise<T>;
64
- withProviderSession<P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit, action: (input: P & {
66
+ withProviderSession<P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit & {
67
+ streaming?: boolean;
68
+ }, action: (input: P & {
65
69
  session: MetorialMcpSession;
66
70
  getSession: MetorialMcpSession['getSession'];
67
71
  getCapabilities: MetorialMcpSession['getCapabilities'];
@@ -69,6 +73,7 @@ declare class Metorial implements MetorialCoreSDK {
69
73
  getServerDeployments: MetorialMcpSession['getServerDeployments'];
70
74
  getToolManager: MetorialMcpSession['getToolManager'];
71
75
  }) => Promise<T>): Promise<T>;
76
+ private withStreamingSession;
72
77
  private inferProvider;
73
78
  waitForOAuthCompletion(sessions: Array<{
74
79
  id: string;
package/dist/index.d.ts CHANGED
@@ -49,7 +49,9 @@ declare class Metorial implements MetorialCoreSDK {
49
49
  get mcp(): {
50
50
  createSession: (init: MetorialMcpSessionInit) => MetorialMcpSession;
51
51
  withSession: <T>(init: MetorialMcpSessionInit, action: (session: MetorialMcpSession) => Promise<T>) => Promise<T>;
52
- withProviderSession: <P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit, action: (input: P & {
52
+ withProviderSession: <P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit & {
53
+ streaming?: boolean;
54
+ }, action: (input: P & {
53
55
  session: MetorialMcpSession;
54
56
  getSession: MetorialMcpSession["getSession"];
55
57
  getCapabilities: MetorialMcpSession["getCapabilities"];
@@ -61,7 +63,9 @@ declare class Metorial implements MetorialCoreSDK {
61
63
  };
62
64
  createMcpConnection(init: MetorialMcpSessionInitServerDeployments[number]): Promise<_metorial_mcp_session.MetorialMcpClient>;
63
65
  withSession<T>(init: MetorialMcpSessionInit, action: (session: MetorialMcpSession) => Promise<T>): Promise<T>;
64
- withProviderSession<P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit, action: (input: P & {
66
+ withProviderSession<P, T>(provider: (session: MetorialMcpSession) => Promise<P>, init: MetorialMcpSessionInit & {
67
+ streaming?: boolean;
68
+ }, action: (input: P & {
65
69
  session: MetorialMcpSession;
66
70
  getSession: MetorialMcpSession['getSession'];
67
71
  getCapabilities: MetorialMcpSession['getCapabilities'];
@@ -69,6 +73,7 @@ declare class Metorial implements MetorialCoreSDK {
69
73
  getServerDeployments: MetorialMcpSession['getServerDeployments'];
70
74
  getToolManager: MetorialMcpSession['getToolManager'];
71
75
  }) => Promise<T>): Promise<T>;
76
+ private withStreamingSession;
72
77
  private inferProvider;
73
78
  waitForOAuthCompletion(sessions: Array<{
74
79
  id: string;
package/dist/index.js CHANGED
@@ -450,6 +450,9 @@ var Metorial = class {
450
450
  }
451
451
  }
452
452
  async withProviderSession(provider, init, action) {
453
+ if (init.streaming) {
454
+ return this.withStreamingSession(provider, init, action);
455
+ }
453
456
  return this.withSession(init, async (session) => {
454
457
  let providerData = await provider(session);
455
458
  return action({
@@ -463,6 +466,40 @@ var Metorial = class {
463
466
  });
464
467
  });
465
468
  }
469
+ async withStreamingSession(provider, init, action) {
470
+ let session = new MetorialMcpSession(this.sdk, init);
471
+ let sessionClosed = false;
472
+ const closeSession = async () => {
473
+ if (!sessionClosed) {
474
+ sessionClosed = true;
475
+ console.log("[Metorial] Closing streaming session");
476
+ await session.close();
477
+ }
478
+ };
479
+ try {
480
+ let providerData = await provider(session);
481
+ let result = await action({
482
+ ...providerData,
483
+ session,
484
+ getSession: session.getSession.bind(session),
485
+ getCapabilities: session.getCapabilities.bind(session),
486
+ getClient: session.getClient.bind(session),
487
+ getServerDeployments: session.getServerDeployments.bind(session),
488
+ getToolManager: session.getToolManager.bind(session),
489
+ closeSession
490
+ });
491
+ setTimeout(async () => {
492
+ if (!sessionClosed) {
493
+ console.log("[Metorial] Streaming timeout reached - auto-closing session");
494
+ await closeSession();
495
+ }
496
+ }, 6e4);
497
+ return result;
498
+ } catch (error) {
499
+ await closeSession();
500
+ throw error;
501
+ }
502
+ }
466
503
  inferProvider(model) {
467
504
  let modelLower = model.toLowerCase();
468
505
  if (modelLower.startsWith("claude-")) {
package/dist/index.js.map CHANGED
@@ -1 +1 @@
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 };"]}
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 & { streaming?: boolean },\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 if (init.streaming) {\n return this.withStreamingSession(provider, init, action);\n }\n\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 async withStreamingSession<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 closeSession: () => Promise<void>;\n }\n ) => Promise<T>\n ): Promise<T> {\n let session = new MetorialMcpSession(this.sdk, init);\n let sessionClosed = false;\n\n const closeSession = async () => {\n if (!sessionClosed) {\n sessionClosed = true;\n console.log('[Metorial] Closing streaming session');\n await session.close();\n }\n };\n\n try {\n let providerData = await provider(session);\n\n let result = await 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 closeSession\n });\n\n setTimeout(async () => {\n if (!sessionClosed) {\n console.log('[Metorial] Streaming timeout reached - auto-closing session');\n await closeSession();\n }\n }, 60000); // 1 minute timeout\n\n return result;\n } catch (error) {\n await closeSession();\n throw error;\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 };"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@metorial/sdk",
3
- "version": "1.1.0",
3
+ "version": "1.1.1",
4
4
  "author": "Metorial Inc.",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -40,14 +40,30 @@
40
40
  "@metorial/xai": "^1.0.1"
41
41
  },
42
42
  "peerDependenciesMeta": {
43
- "@metorial/anthropic": { "optional": true },
44
- "@metorial/deepseek": { "optional": true },
45
- "@metorial/google": { "optional": true },
46
- "@metorial/mistral": { "optional": true },
47
- "@metorial/openai": { "optional": true },
48
- "@metorial/openai-compatible": { "optional": true },
49
- "@metorial/togetherai": { "optional": true },
50
- "@metorial/xai": { "optional": true }
43
+ "@metorial/anthropic": {
44
+ "optional": true
45
+ },
46
+ "@metorial/deepseek": {
47
+ "optional": true
48
+ },
49
+ "@metorial/google": {
50
+ "optional": true
51
+ },
52
+ "@metorial/mistral": {
53
+ "optional": true
54
+ },
55
+ "@metorial/openai": {
56
+ "optional": true
57
+ },
58
+ "@metorial/openai-compatible": {
59
+ "optional": true
60
+ },
61
+ "@metorial/togetherai": {
62
+ "optional": true
63
+ },
64
+ "@metorial/xai": {
65
+ "optional": true
66
+ }
51
67
  },
52
68
  "devDependencies": {
53
69
  "@anthropic-ai/sdk": "^0.30.0",
@@ -60,4 +76,4 @@
60
76
  "typescript": "^5.1.6",
61
77
  "vitest": "^0.34.6"
62
78
  }
63
- }
79
+ }