mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-24 04:10:15 +01:00
refactor: Speed up Config fetching and Setup Config Groundwork 👷🚧 (#1297)
* refactor: move endpoint services to own directory * refactor: make endpointconfig handling more concise, separate logic, and cache result for subsequent serving * refactor: ModelController gets same treatment as EndpointController, draft OverrideController * wip: flesh out override controller more to return real value * refactor: client/api changes in anticipation of override
This commit is contained in:
parent
9b2359fc27
commit
0bae503a0a
27 changed files with 405 additions and 138 deletions
|
|
@ -38,6 +38,8 @@ export const deletePreset = () => '/api/presets/delete';
|
|||
|
||||
export const aiEndpoints = () => '/api/endpoints';
|
||||
|
||||
export const endpointsConfigOverride = () => '/api/endpoints/config/override';
|
||||
|
||||
export const models = () => '/api/models';
|
||||
|
||||
export const tokenizer = () => '/api/tokenizer';
|
||||
|
|
|
|||
|
|
@ -105,14 +105,6 @@ export const searchConversations = async (
|
|||
return request.get(endpoints.search(q, pageNumber));
|
||||
};
|
||||
|
||||
export const getAIEndpoints = (): Promise<t.TEndpointsConfig> => {
|
||||
return request.get(endpoints.aiEndpoints());
|
||||
};
|
||||
|
||||
export const getModels = async (): Promise<t.TModelsConfig> => {
|
||||
return request.get(endpoints.models());
|
||||
};
|
||||
|
||||
export const updateTokenCount = (text: string) => {
|
||||
return request.post(endpoints.tokenizer(), { arg: text });
|
||||
};
|
||||
|
|
@ -154,10 +146,24 @@ export const updateUserPlugins = (payload: t.TUpdateUserPlugins) => {
|
|||
return request.post(endpoints.userPlugins(), payload);
|
||||
};
|
||||
|
||||
/* Config */
|
||||
|
||||
export const getStartupConfig = (): Promise<t.TStartupConfig> => {
|
||||
return request.get(endpoints.config());
|
||||
};
|
||||
|
||||
export const getAIEndpoints = (): Promise<t.TEndpointsConfig> => {
|
||||
return request.get(endpoints.aiEndpoints());
|
||||
};
|
||||
|
||||
export const getModels = async (): Promise<t.TModelsConfig> => {
|
||||
return request.get(endpoints.models());
|
||||
};
|
||||
|
||||
export const getEndpointsConfigOverride = (): Promise<unknown | boolean> => {
|
||||
return request.get(endpoints.endpointsConfigOverride());
|
||||
};
|
||||
|
||||
/* Assistants */
|
||||
|
||||
export const createAssistant = (data: a.AssistantCreateParams): Promise<a.Assistant> => {
|
||||
|
|
|
|||
|
|
@ -15,6 +15,7 @@ export enum QueryKeys {
|
|||
startupConfig = 'startupConfig',
|
||||
assistants = 'assistants',
|
||||
assistant = 'assistant',
|
||||
endpointsConfigOverride = 'endpointsConfigOverride',
|
||||
}
|
||||
|
||||
export enum MutationKeys {
|
||||
|
|
|
|||
|
|
@ -257,6 +257,7 @@ export const useGetEndpointsQuery = <TData = t.TEndpointsConfig>(
|
|||
[QueryKeys.endpoints],
|
||||
() => dataService.getAIEndpoints(),
|
||||
{
|
||||
staleTime: Infinity,
|
||||
refetchOnWindowFocus: false,
|
||||
refetchOnReconnect: false,
|
||||
refetchOnMount: false,
|
||||
|
|
@ -269,6 +270,7 @@ export const useGetModelsQuery = (
|
|||
config?: UseQueryOptions<t.TModelsConfig>,
|
||||
): QueryObserverResult<t.TModelsConfig> => {
|
||||
return useQuery<t.TModelsConfig>([QueryKeys.models], () => dataService.getModels(), {
|
||||
staleTime: Infinity,
|
||||
refetchOnWindowFocus: false,
|
||||
refetchOnReconnect: false,
|
||||
refetchOnMount: false,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue