2024-05-26 16:23:24 +00:00
|
|
|
import { WEBUI_API_BASE_URL, WEBUI_BASE_URL } from '$lib/constants';
|
2023-12-26 19:32:22 +00:00
|
|
|
|
2024-05-24 08:40:48 +00:00
|
|
|
export const getModels = async (token: string = '') => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/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) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
2024-05-24 09:17:48 +00:00
|
|
|
let models = res?.data ?? [];
|
|
|
|
|
2024-05-25 03:29:13 +00:00
|
|
|
models = models
|
|
|
|
.filter((models) => models)
|
2024-05-31 20:11:04 +00:00
|
|
|
// Sort the models
|
2024-05-25 03:29:13 +00:00
|
|
|
.sort((a, b) => {
|
2024-05-31 20:11:04 +00:00
|
|
|
// Check if models have position property
|
|
|
|
const aHasPosition = a.info?.meta?.position !== undefined;
|
|
|
|
const bHasPosition = b.info?.meta?.position !== undefined;
|
|
|
|
|
|
|
|
// If both a and b have the position property
|
|
|
|
if (aHasPosition && bHasPosition) {
|
|
|
|
return a.info.meta.position - b.info.meta.position;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If only a has the position property, it should come first
|
|
|
|
if (aHasPosition) return -1;
|
|
|
|
|
|
|
|
// If only b has the position property, it should come first
|
|
|
|
if (bHasPosition) return 1;
|
|
|
|
|
|
|
|
// Compare case-insensitively by name for models without position property
|
2024-05-25 03:29:13 +00:00
|
|
|
const lowerA = a.name.toLowerCase();
|
|
|
|
const lowerB = b.name.toLowerCase();
|
|
|
|
|
|
|
|
if (lowerA < lowerB) return -1;
|
|
|
|
if (lowerA > lowerB) return 1;
|
|
|
|
|
|
|
|
// If same case-insensitively, sort by original strings,
|
|
|
|
// lowercase will come before uppercase due to ASCII values
|
2024-05-31 20:11:04 +00:00
|
|
|
if (a.name < b.name) return -1;
|
|
|
|
if (a.name > b.name) return 1;
|
2024-05-25 03:29:13 +00:00
|
|
|
|
|
|
|
return 0; // They are equal
|
|
|
|
});
|
2024-05-24 09:17:48 +00:00
|
|
|
|
|
|
|
console.log(models);
|
|
|
|
return models;
|
2024-05-24 08:40:48 +00:00
|
|
|
};
|
|
|
|
|
2024-05-30 09:04:29 +00:00
|
|
|
type ChatCompletedForm = {
|
|
|
|
model: string;
|
|
|
|
messages: string[];
|
|
|
|
chat_id: string;
|
2024-08-07 14:33:24 +00:00
|
|
|
session_id: string;
|
2024-05-30 09:04:29 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export const chatCompleted = async (token: string, body: ChatCompletedForm) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/chat/completed`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify(body)
|
2024-06-09 22:00:38 +00:00
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
2024-07-12 01:47:38 +00:00
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
type ChatActionForm = {
|
|
|
|
model: string;
|
|
|
|
messages: string[];
|
|
|
|
chat_id: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const chatAction = async (token: string, action_id: string, body: ChatActionForm) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/chat/actions/${action_id}`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify(body)
|
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
2024-06-09 22:00:38 +00:00
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const getTaskConfig = async (token: string = '') => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/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);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const updateTaskConfig = async (token: string, config: object) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/config/update`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify(config)
|
2024-05-30 09:04:29 +00:00
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2024-06-09 21:25:31 +00:00
|
|
|
export const generateTitle = async (
|
|
|
|
token: string = '',
|
|
|
|
model: string,
|
|
|
|
prompt: string,
|
|
|
|
chat_id?: string
|
|
|
|
) => {
|
|
|
|
let error = null;
|
|
|
|
|
2024-06-09 21:26:49 +00:00
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/title/completions`, {
|
2024-06-09 21:25:31 +00:00
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
model: model,
|
|
|
|
prompt: prompt,
|
|
|
|
...(chat_id && { chat_id: chat_id })
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.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';
|
|
|
|
};
|
|
|
|
|
2024-06-13 04:18:53 +00:00
|
|
|
export const generateEmoji = async (
|
|
|
|
token: string = '',
|
|
|
|
model: string,
|
|
|
|
prompt: string,
|
|
|
|
chat_id?: string
|
|
|
|
) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/emoji/completions`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
model: model,
|
|
|
|
prompt: prompt,
|
|
|
|
...(chat_id && { chat_id: chat_id })
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.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;
|
|
|
|
}
|
|
|
|
|
2024-06-14 09:30:36 +00:00
|
|
|
const response = res?.choices[0]?.message?.content.replace(/["']/g, '') ?? null;
|
|
|
|
|
|
|
|
if (response) {
|
|
|
|
if (/\p{Extended_Pictographic}/u.test(response)) {
|
|
|
|
return response.match(/\p{Extended_Pictographic}/gu)[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
2024-06-13 04:18:53 +00:00
|
|
|
};
|
|
|
|
|
2024-06-09 21:53:10 +00:00
|
|
|
export const generateSearchQuery = async (
|
|
|
|
token: string = '',
|
|
|
|
model: string,
|
|
|
|
messages: object[],
|
|
|
|
prompt: string
|
|
|
|
) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/query/completions`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
model: model,
|
|
|
|
messages: messages,
|
|
|
|
prompt: prompt
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.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, '') ?? prompt;
|
|
|
|
};
|
|
|
|
|
2024-08-18 18:59:59 +00:00
|
|
|
export const generateMoACompletion = async (
|
|
|
|
token: string = '',
|
|
|
|
model: string,
|
|
|
|
prompt: string,
|
|
|
|
responses: string[]
|
|
|
|
) => {
|
|
|
|
const controller = new AbortController();
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/task/moa/completions`, {
|
|
|
|
signal: controller.signal,
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
model: model,
|
|
|
|
prompt: prompt,
|
|
|
|
responses: responses,
|
|
|
|
stream: true
|
|
|
|
})
|
|
|
|
}).catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return [res, controller];
|
|
|
|
};
|
|
|
|
|
2024-05-30 04:26:57 +00:00
|
|
|
export const getPipelinesList = async (token: string = '') => {
|
2024-05-28 19:04:19 +00:00
|
|
|
let error = null;
|
|
|
|
|
2024-05-30 04:26:57 +00:00
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/pipelines/list`, {
|
|
|
|
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);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
let pipelines = res?.data ?? [];
|
|
|
|
return pipelines;
|
|
|
|
};
|
|
|
|
|
2024-06-05 20:57:48 +00:00
|
|
|
export const uploadPipeline = async (token: string, file: File, urlIdx: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
// Create a new FormData object to handle the file upload
|
|
|
|
const formData = new FormData();
|
|
|
|
formData.append('file', file);
|
|
|
|
formData.append('urlIdx', urlIdx);
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/pipelines/upload`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
// 'Content-Type': 'multipart/form-data' is not needed as Fetch API will set it automatically
|
|
|
|
},
|
|
|
|
body: formData
|
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2024-05-30 05:03:22 +00:00
|
|
|
export const downloadPipeline = async (token: string, url: string, urlIdx: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/pipelines/add`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
url: url,
|
|
|
|
urlIdx: urlIdx
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const deletePipeline = async (token: string, id: string, urlIdx: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/pipelines/delete`, {
|
|
|
|
method: 'DELETE',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
id: id,
|
|
|
|
urlIdx: urlIdx
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.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 = err;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2024-05-30 04:26:57 +00:00
|
|
|
export const getPipelines = async (token: string, urlIdx?: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const searchParams = new URLSearchParams();
|
2024-05-30 05:41:51 +00:00
|
|
|
if (urlIdx !== undefined) {
|
2024-05-30 04:26:57 +00:00
|
|
|
searchParams.append('urlIdx', urlIdx);
|
|
|
|
}
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/pipelines?${searchParams.toString()}`, {
|
2024-05-28 19:04:19 +00:00
|
|
|
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);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
let pipelines = res?.data ?? [];
|
|
|
|
return pipelines;
|
|
|
|
};
|
|
|
|
|
2024-05-30 05:18:27 +00:00
|
|
|
export const getPipelineValves = async (token: string, pipeline_id: string, urlIdx: string) => {
|
2024-05-28 19:32:49 +00:00
|
|
|
let error = null;
|
|
|
|
|
2024-05-30 05:18:27 +00:00
|
|
|
const searchParams = new URLSearchParams();
|
2024-05-30 05:41:51 +00:00
|
|
|
if (urlIdx !== undefined) {
|
2024-05-30 05:18:27 +00:00
|
|
|
searchParams.append('urlIdx', urlIdx);
|
|
|
|
}
|
|
|
|
|
|
|
|
const res = await fetch(
|
|
|
|
`${WEBUI_BASE_URL}/api/pipelines/${pipeline_id}/valves?${searchParams.toString()}`,
|
|
|
|
{
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
}
|
2024-05-28 19:32:49 +00:00
|
|
|
}
|
2024-05-30 05:18:27 +00:00
|
|
|
)
|
2024-05-28 19:32:49 +00:00
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2024-05-30 05:18:27 +00:00
|
|
|
export const getPipelineValvesSpec = async (token: string, pipeline_id: string, urlIdx: string) => {
|
2024-05-28 19:32:49 +00:00
|
|
|
let error = null;
|
|
|
|
|
2024-05-30 05:18:27 +00:00
|
|
|
const searchParams = new URLSearchParams();
|
2024-05-30 05:41:51 +00:00
|
|
|
if (urlIdx !== undefined) {
|
2024-05-30 05:18:27 +00:00
|
|
|
searchParams.append('urlIdx', urlIdx);
|
|
|
|
}
|
|
|
|
|
|
|
|
const res = await fetch(
|
|
|
|
`${WEBUI_BASE_URL}/api/pipelines/${pipeline_id}/valves/spec?${searchParams.toString()}`,
|
|
|
|
{
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
}
|
2024-05-28 19:32:49 +00:00
|
|
|
}
|
2024-05-30 05:18:27 +00:00
|
|
|
)
|
2024-05-28 19:32:49 +00:00
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const updatePipelineValves = async (
|
|
|
|
token: string = '',
|
|
|
|
pipeline_id: string,
|
2024-05-30 05:18:27 +00:00
|
|
|
valves: object,
|
|
|
|
urlIdx: string
|
2024-05-28 19:32:49 +00:00
|
|
|
) => {
|
|
|
|
let error = null;
|
|
|
|
|
2024-05-30 05:18:27 +00:00
|
|
|
const searchParams = new URLSearchParams();
|
2024-05-30 05:41:51 +00:00
|
|
|
if (urlIdx !== undefined) {
|
2024-05-30 05:18:27 +00:00
|
|
|
searchParams.append('urlIdx', urlIdx);
|
|
|
|
}
|
|
|
|
|
|
|
|
const res = await fetch(
|
|
|
|
`${WEBUI_BASE_URL}/api/pipelines/${pipeline_id}/valves/update?${searchParams.toString()}`,
|
|
|
|
{
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Accept: 'application/json',
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...(token && { authorization: `Bearer ${token}` })
|
|
|
|
},
|
|
|
|
body: JSON.stringify(valves)
|
|
|
|
}
|
|
|
|
)
|
2024-05-28 19:32:49 +00:00
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
2024-05-28 20:05:31 +00:00
|
|
|
|
|
|
|
if ('detail' in err) {
|
|
|
|
error = err.detail;
|
|
|
|
} else {
|
|
|
|
error = err;
|
|
|
|
}
|
2024-05-28 19:32:49 +00:00
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2023-12-26 19:32:22 +00:00
|
|
|
export const getBackendConfig = async () => {
|
2023-12-26 11:28:30 +00:00
|
|
|
let error = null;
|
|
|
|
|
2024-02-22 02:12:01 +00:00
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/config`, {
|
2023-12-26 11:28:30 +00:00
|
|
|
method: 'GET',
|
2024-08-19 14:49:40 +00:00
|
|
|
credentials: 'include',
|
2023-12-26 11:28:30 +00:00
|
|
|
headers: {
|
2023-12-26 19:32:22 +00:00
|
|
|
'Content-Type': 'application/json'
|
2023-12-26 11:28:30 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
2023-12-26 19:32:22 +00:00
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
2023-12-26 11:28:30 +00:00
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
2024-02-25 19:55:15 +00:00
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
2023-12-26 19:32:22 +00:00
|
|
|
return res;
|
2023-12-26 11:28:30 +00:00
|
|
|
};
|
2024-02-23 08:30:26 +00:00
|
|
|
|
|
|
|
export const getChangelog = async () => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/changelog`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
2024-02-25 19:55:15 +00:00
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const getVersionUpdates = async () => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/version/updates`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
2024-02-23 08:30:26 +00:00
|
|
|
return res;
|
|
|
|
};
|
2024-03-10 05:29:04 +00:00
|
|
|
|
|
|
|
export const getModelFilterConfig = async (token: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/config/model/filter`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const updateModelFilterConfig = async (
|
|
|
|
token: string,
|
|
|
|
enabled: boolean,
|
|
|
|
models: string[]
|
|
|
|
) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/config/model/filter`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
enabled: enabled,
|
|
|
|
models: models
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
2024-03-21 01:35:54 +00:00
|
|
|
|
|
|
|
export const getWebhookUrl = async (token: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/webhook`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res.url;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const updateWebhookUrl = async (token: string, url: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/webhook`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
url: url
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res.url;
|
|
|
|
};
|
2024-05-09 15:49:54 +00:00
|
|
|
|
2024-05-26 16:23:24 +00:00
|
|
|
export const getCommunitySharingEnabledStatus = async (token: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/community_sharing`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const toggleCommunitySharingEnabledStatus = async (token: string) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/community_sharing/toggle`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err.detail;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|
|
|
|
|
2024-05-09 15:49:54 +00:00
|
|
|
export const getModelConfig = async (token: string): Promise<GlobalModelConfig> => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/config/models`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res.models;
|
|
|
|
};
|
|
|
|
|
|
|
|
export interface ModelConfig {
|
|
|
|
id: string;
|
2024-05-19 10:46:24 +00:00
|
|
|
name: string;
|
2024-05-21 21:05:16 +00:00
|
|
|
meta: ModelMeta;
|
|
|
|
base_model_id?: string;
|
2024-05-19 10:46:24 +00:00
|
|
|
params: ModelParams;
|
|
|
|
}
|
|
|
|
|
2024-05-21 21:05:16 +00:00
|
|
|
export interface ModelMeta {
|
2024-05-09 15:49:54 +00:00
|
|
|
description?: string;
|
2024-05-25 07:44:21 +00:00
|
|
|
capabilities?: object;
|
2024-08-20 00:44:09 +00:00
|
|
|
profile_image_url?: string;
|
2024-05-09 15:49:54 +00:00
|
|
|
}
|
|
|
|
|
2024-05-21 21:05:16 +00:00
|
|
|
export interface ModelParams {}
|
|
|
|
|
2024-05-19 10:46:24 +00:00
|
|
|
export type GlobalModelConfig = ModelConfig[];
|
2024-05-09 15:49:54 +00:00
|
|
|
|
|
|
|
export const updateModelConfig = async (token: string, config: GlobalModelConfig) => {
|
|
|
|
let error = null;
|
|
|
|
|
|
|
|
const res = await fetch(`${WEBUI_BASE_URL}/api/config/models`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
Authorization: `Bearer ${token}`
|
|
|
|
},
|
2024-05-19 10:46:24 +00:00
|
|
|
body: JSON.stringify({
|
|
|
|
models: config
|
|
|
|
})
|
2024-05-09 15:49:54 +00:00
|
|
|
})
|
|
|
|
.then(async (res) => {
|
|
|
|
if (!res.ok) throw await res.json();
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
error = err;
|
|
|
|
return null;
|
|
|
|
});
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
};
|