2024-10-13 18:53:43 +00:00
|
|
|
// @ts-nocheck
|
|
|
|
// Preventing TS checks with files presented in the video for a better presentation.
|
2024-07-17 18:54:46 +00:00
|
|
|
import { streamText as _streamText, convertToCoreMessages } from 'ai';
|
2024-10-13 18:53:43 +00:00
|
|
|
import { getModel } from '~/lib/.server/llm/model';
|
2024-07-17 18:54:46 +00:00
|
|
|
import { MAX_TOKENS } from './constants';
|
|
|
|
import { getSystemPrompt } from './prompts';
|
2024-10-13 18:53:43 +00:00
|
|
|
import { MODEL_LIST, DEFAULT_MODEL, DEFAULT_PROVIDER } from '~/utils/constants';
|
2024-11-09 07:29:42 +00:00
|
|
|
import { logger } from '~/utils/logger';
|
2024-07-17 18:54:46 +00:00
|
|
|
|
|
|
|
interface ToolResult<Name extends string, Args, Result> {
|
|
|
|
toolCallId: string;
|
|
|
|
toolName: Name;
|
|
|
|
args: Args;
|
|
|
|
result: Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface Message {
|
|
|
|
role: 'user' | 'assistant';
|
|
|
|
content: string;
|
|
|
|
toolInvocations?: ToolResult<string, unknown, unknown>[];
|
2024-10-13 18:53:43 +00:00
|
|
|
model?: string;
|
2024-07-17 18:54:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export type Messages = Message[];
|
|
|
|
|
|
|
|
export type StreamingOptions = Omit<Parameters<typeof _streamText>[0], 'model'>;
|
|
|
|
|
2024-10-13 18:53:43 +00:00
|
|
|
function extractModelFromMessage(message: Message): { model: string; content: string } {
|
|
|
|
const modelRegex = /^\[Model: (.*?)\]\n\n/;
|
|
|
|
const match = message.content.match(modelRegex);
|
|
|
|
|
|
|
|
if (match) {
|
|
|
|
const model = match[1];
|
|
|
|
const content = message.content.replace(modelRegex, '');
|
|
|
|
return { model, content };
|
|
|
|
}
|
|
|
|
|
|
|
|
// Default model if not specified
|
|
|
|
return { model: DEFAULT_MODEL, content: message.content };
|
|
|
|
}
|
|
|
|
|
2024-07-17 18:54:46 +00:00
|
|
|
export function streamText(messages: Messages, env: Env, options?: StreamingOptions) {
|
2024-10-13 18:53:43 +00:00
|
|
|
let currentModel = DEFAULT_MODEL;
|
2024-11-09 07:29:42 +00:00
|
|
|
logger.debug('model List', JSON.stringify(MODEL_LIST, null, 2))
|
2024-10-13 18:53:43 +00:00
|
|
|
const processedMessages = messages.map((message) => {
|
|
|
|
if (message.role === 'user') {
|
|
|
|
const { model, content } = extractModelFromMessage(message);
|
|
|
|
if (model && MODEL_LIST.find((m) => m.name === model)) {
|
|
|
|
currentModel = model; // Update the current model
|
|
|
|
}
|
|
|
|
return { ...message, content };
|
|
|
|
}
|
|
|
|
return message;
|
|
|
|
});
|
|
|
|
|
|
|
|
const provider = MODEL_LIST.find((model) => model.name === currentModel)?.provider || DEFAULT_PROVIDER;
|
|
|
|
|
2024-07-17 18:54:46 +00:00
|
|
|
return _streamText({
|
2024-10-13 18:53:43 +00:00
|
|
|
model: getModel(provider, currentModel, env),
|
2024-07-17 18:54:46 +00:00
|
|
|
system: getSystemPrompt(),
|
|
|
|
maxTokens: MAX_TOKENS,
|
2024-10-13 18:53:43 +00:00
|
|
|
// headers: {
|
|
|
|
// 'anthropic-beta': 'max-tokens-3-5-sonnet-2024-07-15',
|
|
|
|
// },
|
|
|
|
messages: convertToCoreMessages(processedMessages),
|
2024-07-17 18:54:46 +00:00
|
|
|
...options,
|
|
|
|
});
|
|
|
|
}
|