123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510 |
- import { OPENAI_API_BASE_URL } from '$lib/constants';
- import { promptTemplate } from '$lib/utils';
- import { type Model, models, settings } from '$lib/stores';
- export const getOpenAIConfig = async (token: string = '') => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/config`, {
- method: 'GET',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- }
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res;
- };
- export const updateOpenAIConfig = async (token: string = '', enable_openai_api: boolean) => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/config/update`, {
- method: 'POST',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- },
- body: JSON.stringify({
- enable_openai_api: enable_openai_api
- })
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res;
- };
- export const getOpenAIUrls = async (token: string = '') => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/urls`, {
- method: 'GET',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- }
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res.OPENAI_API_BASE_URLS;
- };
- export const updateOpenAIUrls = async (token: string = '', urls: string[]) => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/urls/update`, {
- method: 'POST',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- },
- body: JSON.stringify({
- urls: urls
- })
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res.OPENAI_API_BASE_URLS;
- };
- export const getOpenAIKeys = async (token: string = '') => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/keys`, {
- method: 'GET',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- }
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res.OPENAI_API_KEYS;
- };
- export const updateOpenAIKeys = async (token: string = '', keys: string[]) => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/keys/update`, {
- method: 'POST',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- },
- body: JSON.stringify({
- keys: keys
- })
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- } else {
- error = 'Server connection failed';
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res.OPENAI_API_KEYS;
- };
- export const getOpenAIModels = async (token: string = '') => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/models`, {
- method: 'GET',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- ...(token && { authorization: `Bearer ${token}` })
- }
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- error = `OpenAI: ${err?.error?.message ?? 'Network Problem'}`;
- return [];
- });
- if (error) {
- throw error;
- }
- const models = Array.isArray(res) ? res : res?.data ?? null;
- return models
- ? models
- .map((model) => ({
- id: model.id,
- name: model.name ?? model.id,
- external: true,
- custom_info: model.custom_info
- }))
- .sort((a, b) => {
- return a.name.localeCompare(b.name);
- })
- : models;
- };
- export const getOpenAIModelsDirect = async (
- base_url: string = 'https://api.openai.com/v1',
- api_key: string = ''
- ) => {
- let error = null;
- const res = await fetch(`${base_url}/models`, {
- method: 'GET',
- headers: {
- 'Content-Type': 'application/json',
- Authorization: `Bearer ${api_key}`
- }
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- error = `OpenAI: ${err?.error?.message ?? 'Network Problem'}`;
- return null;
- });
- if (error) {
- throw error;
- }
- const models = Array.isArray(res) ? res : res?.data ?? null;
- return models
- .map((model) => ({ id: model.id, name: model.name ?? model.id, external: true }))
- .filter((model) => (base_url.includes('openai') ? model.name.includes('gpt') : true))
- .sort((a, b) => {
- return a.name.localeCompare(b.name);
- });
- };
- export const generateOpenAIChatCompletion = async (
- token: string = '',
- body: object,
- url: string = OPENAI_API_BASE_URL
- ): Promise<[Response | null, AbortController]> => {
- const controller = new AbortController();
- let error = null;
- const res = await fetch(`${url}/chat/completions`, {
- signal: controller.signal,
- method: 'POST',
- headers: {
- Authorization: `Bearer ${token}`,
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify(body)
- }).catch((err) => {
- console.log(err);
- error = err;
- return null;
- });
- if (error) {
- throw error;
- }
- return [res, controller];
- };
- export const synthesizeOpenAISpeech = async (
- token: string = '',
- speaker: string = 'alloy',
- text: string = '',
- model: string = 'tts-1'
- ) => {
- let error = null;
- const res = await fetch(`${OPENAI_API_BASE_URL}/audio/speech`, {
- method: 'POST',
- headers: {
- Authorization: `Bearer ${token}`,
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify({
- model: model,
- input: text,
- voice: speaker
- })
- }).catch((err) => {
- console.log(err);
- error = err;
- return null;
- });
- if (error) {
- throw error;
- }
- return res;
- };
- export const generateTitle = async (
- token: string = '',
- template: string,
- model: string,
- prompt: string,
- url: string = OPENAI_API_BASE_URL
- ) => {
- let error = null;
- template = promptTemplate(template, prompt);
- console.log(template);
- const res = await fetch(`${url}/chat/completions`, {
- method: 'POST',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- Authorization: `Bearer ${token}`
- },
- body: JSON.stringify({
- model: model,
- messages: [
- {
- role: 'user',
- content: template
- }
- ],
- stream: false,
- // Restricting the max tokens to 50 to avoid long titles
- max_tokens: 50
- })
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- }
- return null;
- });
- if (error) {
- throw error;
- }
- return res?.choices[0]?.message?.content.replace(/["']/g, '') ?? 'New Chat';
- };
- export const generateSearchQuery = async (
- token: string = '',
- model: string,
- previousMessages: string[],
- prompt: string,
- url: string = OPENAI_API_BASE_URL
- ): Promise<string | undefined> => {
- let error = null;
- // TODO: Allow users to specify the prompt
- // Get the current date in the format "January 20, 2024"
- const currentDate = new Intl.DateTimeFormat('en-US', {
- year: 'numeric',
- month: 'long',
- day: '2-digit'
- }).format(new Date());
- const yesterdayDate = new Intl.DateTimeFormat('en-US', {
- year: 'numeric',
- month: 'long',
- day: '2-digit'
- }).format(new Date());
- const res = await fetch(`${url}/chat/completions`, {
- method: 'POST',
- headers: {
- Accept: 'application/json',
- 'Content-Type': 'application/json',
- Authorization: `Bearer ${token}`
- },
- body: JSON.stringify({
- model: model,
- // Few shot prompting
- messages: [
- {
- role: 'assistant',
- content: `You are tasked with generating web search queries. Give me an appropriate query to answer my question for google search. Answer with only the query. Today is ${currentDate}.`
- },
- {
- role: 'user',
- content: `Previous Questions:
- - Who is the president of France?
- Current Question: What about Mexico?`
- },
- {
- role: 'assistant',
- content: 'President of Mexico'
- },
- {
- role: 'user',
- content: `Previous questions:
- - When is the next formula 1 grand prix?
- Current Question: Where is it being hosted?`
- },
- {
- role: 'assistant',
- content: 'location of next formula 1 grand prix'
- },
- {
- role: 'user',
- content: 'Current Question: What type of printhead does the Epson F2270 DTG printer use?'
- },
- {
- role: 'assistant',
- content: 'Epson F2270 DTG printer printhead'
- },
- {
- role: 'user',
- content: 'What were the news yesterday?'
- },
- {
- role: 'assistant',
- content: `news ${yesterdayDate}`
- },
- {
- role: 'user',
- content: 'What is the current weather in Paris?'
- },
- {
- role: 'assistant',
- content: `weather in Paris ${currentDate}`
- },
- {
- role: 'user',
- content:
- (previousMessages.length > 0
- ? `Previous Questions:\n${previousMessages.join('\n')}\n\n`
- : '') + `Current Question: ${prompt}`
- }
- ],
- stream: false,
- // Restricting the max tokens to 30 to avoid long search queries
- max_tokens: 30
- })
- })
- .then(async (res) => {
- if (!res.ok) throw await res.json();
- return res.json();
- })
- .catch((err) => {
- console.log(err);
- if ('detail' in err) {
- error = err.detail;
- }
- return undefined;
- });
- if (error) {
- throw error;
- }
- return res?.choices[0]?.message?.content.replace(/["']/g, '') ?? undefined;
- };
|