UNPKG

@lobehub/chat

Version:

Lobe Chat - an open-source, high-performance chatbot framework that supports speech synthesis, multimodal, and extensible Function Call plugin system. Supports one-click free deployment of your private ChatGPT/LLM web application.

79 lines (70 loc) 2.53 kB
import type { ChatModelCard } from '@/types/llm'; import { AgentRuntimeErrorType } from '../error'; import { ChatCompletionErrorPayload, ModelProvider } from '../types'; import { createOpenAICompatibleRuntime } from '../utils/openaiCompatibleFactory'; export interface InfiniAIModelCard { id: string; } export const LobeInfiniAI = createOpenAICompatibleRuntime({ baseURL: 'https://cloud.infini-ai.com/maas/v1', chatCompletion: { handleError(error): Omit<ChatCompletionErrorPayload, 'provider'> | undefined { let errorResponse: Response | undefined; if (error instanceof Response) { errorResponse = error; } else if ('status' in (error as any)) { errorResponse = error as Response; } if (errorResponse) { if (errorResponse.status === 401) { return { error, errorType: AgentRuntimeErrorType.InvalidProviderAPIKey, }; } if (errorResponse.status === 429) { return { error, errorType: AgentRuntimeErrorType.QuotaLimitReached, }; } } return { error, }; }, }, debug: { chatCompletion: () => process.env.DEBUG_INFINIAI_CHAT_COMPLETION === '1', }, models: async ({ client }) => { const { LOBE_DEFAULT_MODEL_LIST } = await import('@/config/aiModels'); const reasoningKeywords = ['deepseek-r1', 'qwq', 'qwen3']; const visionKeywords = ['qwen2.5-vl']; const modelsPage = (await client.models.list()) as any; const modelList: InfiniAIModelCard[] = modelsPage.data; return modelList .map((model) => { const knownModel = LOBE_DEFAULT_MODEL_LIST.find( (m) => model.id.toLowerCase() === m.id.toLowerCase(), ); return { contextWindowTokens: knownModel?.contextWindowTokens ?? undefined, displayName: knownModel?.displayName ?? undefined, enabled: knownModel?.enabled || false, functionCall: knownModel?.abilities?.functionCall || false, id: model.id, reasoning: reasoningKeywords.some((keyword) => model.id.toLowerCase().includes(keyword)) || knownModel?.abilities?.reasoning || false, vision: visionKeywords.some((keyword) => model.id.toLowerCase().includes(keyword)) || knownModel?.abilities?.vision || false, }; }) .filter(Boolean) as ChatModelCard[]; }, provider: ModelProvider.InfiniAI, });