UNPKG

@llumiverse/drivers

Version:

LLM driver implementations. Currently supported are: openai, huggingface, bedrock, replicate.

58 lines 2.42 kB
import { Providers } from "@llumiverse/core"; import { formatOpenAILikeMultimodalPrompt } from "../openai/openai_format.js"; import { FetchClient } from "@vertesia/api-fetch-client"; import OpenAI from "openai"; import { BaseOpenAIDriver } from "../openai/index.js"; export class xAIDriver extends BaseOpenAIDriver { service; provider = Providers.xai; xai_service; DEFAULT_ENDPOINT = "https://api.x.ai/v1"; constructor(opts) { super(opts); if (!opts.apiKey) { throw new Error("apiKey is required"); } this.service = new OpenAI({ apiKey: opts.apiKey, baseURL: opts.endpoint ?? this.DEFAULT_ENDPOINT, }); this.xai_service = new FetchClient(opts.endpoint ?? this.DEFAULT_ENDPOINT).withAuthCallback(async () => `Bearer ${opts.apiKey}`); //this.formatPrompt = this._formatPrompt; //TODO: fix xai prompt formatting } async _formatPrompt(segments, opts) { const options = { multimodal: opts.model.includes("vision"), schema: opts.result_schema, useToolForFormatting: false, }; const p = await formatOpenAILikeMultimodalPrompt(segments, { ...options, ...opts }); return p; } // Note: We intentionally do NOT override extractDataFromResponse here. // The base class implementation properly handles tool_calls extraction. // xAI's API is OpenAI-compatible and returns tool_calls in the same format. async listModels() { const [lm, em] = await Promise.all([ this.xai_service.get("/language-models"), this.xai_service.get("/embedding-models") ]); em.models.forEach(m => { m.output_modalities.push("vectors"); }); const models = [...lm.models, ...em.models].map(model => { return { id: model.id, provider: this.provider, name: model.id, description: `${model.id} by ${model.owned_by}`, is_multimodal: model.input_modalities.length > 1, input_modalities: model.input_modalities, output_modalities: model.output_modalities, tags: [...model.input_modalities.map(m => `i:${m}`), ...model.output_modalities.map(m => `o:${m}`)], }; }); return models; } } //# sourceMappingURL=index.js.map