UNPKG

@llumiverse/drivers

Version:

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

64 lines 2.49 kB
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; 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.provider = "xai"; //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; } extractDataFromResponse(_options, result) { return { result: result.choices[0].message.content ? [{ type: "text", value: result.choices[0].message.content }] : [], finish_reason: result.choices[0].finish_reason, token_usage: { prompt: result.usage?.prompt_tokens, result: result.usage?.completion_tokens, total: result.usage?.total_tokens, } }; } 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.object, description: model.object, is_multimodal: model.input_modalities.length > 1, tags: [...model.input_modalities.map(m => `ì:${m}`), ...model.output_modalities.map(m => `ì:${m}`)], }; }); return models; } } //# sourceMappingURL=index.js.map