mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00

* 🔧 refactor: Remove modelSpecs prop from ModelSelector and related components
* fix: Update submission.conversationId references in SSE hooks and data types as was incorrectly typed
* feat: Allow showing specific endpoints alongside model specs via `addedEndpoints` field
* feat: allowed agents providers via `agents.allowedProviders` field
* fix: bump dicebear/sharp dependencies to resolve CVE-2024-12905 and improve avatar gen logic
* fix: rename variable for clarity in loadDefaultInterface function
* fix: add keepAddedConvos option to newConversation calls for modular chat support
* fix: include model information in endpoint selection for improved context
* fix: update data-provider version to 0.7.78 and increment config version to 1.2.4
88 lines
2.9 KiB
JavaScript
88 lines
2.9 KiB
JavaScript
const { CacheKeys, EModelEndpoint, orderEndpointsConfig } = require('librechat-data-provider');
|
|
const loadDefaultEndpointsConfig = require('./loadDefaultEConfig');
|
|
const loadConfigEndpoints = require('./loadConfigEndpoints');
|
|
const getLogStores = require('~/cache/getLogStores');
|
|
|
|
/**
|
|
*
|
|
* @param {ServerRequest} req
|
|
* @returns {Promise<TEndpointsConfig>}
|
|
*/
|
|
async function getEndpointsConfig(req) {
|
|
const cache = getLogStores(CacheKeys.CONFIG_STORE);
|
|
const cachedEndpointsConfig = await cache.get(CacheKeys.ENDPOINT_CONFIG);
|
|
if (cachedEndpointsConfig) {
|
|
return cachedEndpointsConfig;
|
|
}
|
|
|
|
const defaultEndpointsConfig = await loadDefaultEndpointsConfig(req);
|
|
const customConfigEndpoints = await loadConfigEndpoints(req);
|
|
|
|
/** @type {TEndpointsConfig} */
|
|
const mergedConfig = { ...defaultEndpointsConfig, ...customConfigEndpoints };
|
|
if (mergedConfig[EModelEndpoint.assistants] && req.app.locals?.[EModelEndpoint.assistants]) {
|
|
const { disableBuilder, retrievalModels, capabilities, version, ..._rest } =
|
|
req.app.locals[EModelEndpoint.assistants];
|
|
|
|
mergedConfig[EModelEndpoint.assistants] = {
|
|
...mergedConfig[EModelEndpoint.assistants],
|
|
version,
|
|
retrievalModels,
|
|
disableBuilder,
|
|
capabilities,
|
|
};
|
|
}
|
|
if (mergedConfig[EModelEndpoint.agents] && req.app.locals?.[EModelEndpoint.agents]) {
|
|
const { disableBuilder, capabilities, allowedProviders, ..._rest } =
|
|
req.app.locals[EModelEndpoint.agents];
|
|
|
|
mergedConfig[EModelEndpoint.agents] = {
|
|
...mergedConfig[EModelEndpoint.agents],
|
|
allowedProviders,
|
|
disableBuilder,
|
|
capabilities,
|
|
};
|
|
}
|
|
|
|
if (
|
|
mergedConfig[EModelEndpoint.azureAssistants] &&
|
|
req.app.locals?.[EModelEndpoint.azureAssistants]
|
|
) {
|
|
const { disableBuilder, retrievalModels, capabilities, version, ..._rest } =
|
|
req.app.locals[EModelEndpoint.azureAssistants];
|
|
|
|
mergedConfig[EModelEndpoint.azureAssistants] = {
|
|
...mergedConfig[EModelEndpoint.azureAssistants],
|
|
version,
|
|
retrievalModels,
|
|
disableBuilder,
|
|
capabilities,
|
|
};
|
|
}
|
|
|
|
if (mergedConfig[EModelEndpoint.bedrock] && req.app.locals?.[EModelEndpoint.bedrock]) {
|
|
const { availableRegions } = req.app.locals[EModelEndpoint.bedrock];
|
|
mergedConfig[EModelEndpoint.bedrock] = {
|
|
...mergedConfig[EModelEndpoint.bedrock],
|
|
availableRegions,
|
|
};
|
|
}
|
|
|
|
const endpointsConfig = orderEndpointsConfig(mergedConfig);
|
|
|
|
await cache.set(CacheKeys.ENDPOINT_CONFIG, endpointsConfig);
|
|
return endpointsConfig;
|
|
}
|
|
|
|
/**
|
|
* @param {ServerRequest} req
|
|
* @param {import('librechat-data-provider').AgentCapabilities} capability
|
|
* @returns {Promise<boolean>}
|
|
*/
|
|
const checkCapability = async (req, capability) => {
|
|
const endpointsConfig = await getEndpointsConfig(req);
|
|
const capabilities = endpointsConfig?.[EModelEndpoint.agents]?.capabilities ?? [];
|
|
return capabilities.includes(capability);
|
|
};
|
|
|
|
module.exports = { getEndpointsConfig, checkCapability };
|