Spaces:
				
			
			
	
			
			
		Paused
		
	
	
	
			
			
	
	
	
	
		
		
		Paused
		
	File size: 1,693 Bytes
			
			| 8c28b44 a8a9533 8c28b44 a8a9533 77340d8 8c28b44 77340d8 8c28b44 77340d8 8c28b44 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | import { z } from "zod";
import type { EmbeddingEndpoint, Embedding } from "../embeddingEndpoints";
import { chunk } from "$lib/utils/chunk";
import { env } from "$env/dynamic/private";
export const embeddingEndpointOpenAIParametersSchema = z.object({
	weight: z.number().int().positive().default(1),
	model: z.any(),
	type: z.literal("openai"),
	url: z.string().url().default("https://api.openai.com/v1/embeddings"),
	apiKey: z.string().default(env.OPENAI_API_KEY),
	defaultHeaders: z.record(z.string()).default({}),
});
export async function embeddingEndpointOpenAI(
	input: z.input<typeof embeddingEndpointOpenAIParametersSchema>
): Promise<EmbeddingEndpoint> {
	const { url, model, apiKey, defaultHeaders } =
		embeddingEndpointOpenAIParametersSchema.parse(input);
	const maxBatchSize = model.maxBatchSize || 100;
	return async ({ inputs }) => {
		const requestURL = new URL(url);
		const batchesInputs = chunk(inputs, maxBatchSize);
		const batchesResults = await Promise.all(
			batchesInputs.map(async (batchInputs) => {
				const response = await fetch(requestURL, {
					method: "POST",
					headers: {
						Accept: "application/json",
						"Content-Type": "application/json",
						...(apiKey ? { Authorization: `Bearer ${apiKey}` } : {}),
						...defaultHeaders,
					},
					body: JSON.stringify({ input: batchInputs, model: model.name }),
				});
				const embeddings: Embedding[] = [];
				const responseObject = await response.json();
				for (const embeddingObject of responseObject.data) {
					embeddings.push(embeddingObject.embedding);
				}
				return embeddings;
			})
		);
		const flatAllEmbeddings = batchesResults.flat();
		return flatAllEmbeddings;
	};
}
 | 
 
			
