UNPKG

@huggingface/inference

Version:

Typescript client for the Hugging Face Inference Providers and Inference Endpoints

27 lines (26 loc) 1.32 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.chatCompletion = chatCompletion; const getInferenceProviderMapping_js_1 = require("../../lib/getInferenceProviderMapping.js"); const getProviderHelper_js_1 = require("../../lib/getProviderHelper.js"); const request_js_1 = require("../../utils/request.js"); const providerHelper_js_1 = require("../../providers/providerHelper.js"); /** * Use the chat completion endpoint to generate a response to a prompt, using OpenAI message completion API no stream */ async function chatCompletion(args, options) { let providerHelper; if (!args.provider || args.provider === "auto") { // Special case: we have a dedicated auto-router for conversational models. No need to fetch provider mapping. providerHelper = new providerHelper_js_1.AutoRouterConversationalTask(); } else { const provider = await (0, getInferenceProviderMapping_js_1.resolveProvider)(args.provider, args.model, args.endpointUrl); providerHelper = (0, getProviderHelper_js_1.getProviderHelper)(provider, "conversational"); } const { data: response } = await (0, request_js_1.innerRequest)(args, providerHelper, { ...options, task: "conversational", }); return providerHelper.getResponse(response); }