mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
* chore: replace violation cache accessors with enum * chore: fix test * chore(fileSchema): index timestamps * fix(ActionService): use encoding/caching strategy for handling assistant function character length limit * refactor(actions): async `domainParser` also resolve retrieved model (which is deployment name) to user-defined model * style(AssistantAction): add `whitespace-nowrap` for ellipsis * refactor(ActionService): if domain is less than or equal to encoded domain fixed length, return domain with replacement of separator * refactor(actions): use sessions/transactions for updating Assistant Action database records * chore: remove TTL from ENCODED_DOMAINS cache * refactor(domainParser): minor optimization and add tests * fix(spendTokens): use txData.user for token usage logging * refactor(actions): add helper function `withSession` for database operations with sessions/transactions * fix(PluginsClient): logger debug `message` field edge case
46 lines
2 KiB
JavaScript
46 lines
2 KiB
JavaScript
const mongoose = require('mongoose');
|
|
const assistantSchema = require('./schema/assistant');
|
|
|
|
const Assistant = mongoose.model('assistant', assistantSchema);
|
|
|
|
/**
|
|
* Update an assistant with new data without overwriting existing properties,
|
|
* or create a new assistant if it doesn't exist, within a transaction session if provided.
|
|
*
|
|
* @param {Object} searchParams - The search parameters to find the assistant to update.
|
|
* @param {string} searchParams.assistant_id - The ID of the assistant to update.
|
|
* @param {string} searchParams.user - The user ID of the assistant's author.
|
|
* @param {Object} updateData - An object containing the properties to update.
|
|
* @param {mongoose.ClientSession} [session] - The transaction session to use (optional).
|
|
* @returns {Promise<Object>} The updated or newly created assistant document as a plain object.
|
|
*/
|
|
const updateAssistant = async (searchParams, updateData, session = null) => {
|
|
const options = { new: true, upsert: true, session };
|
|
return await Assistant.findOneAndUpdate(searchParams, updateData, options).lean();
|
|
};
|
|
|
|
/**
|
|
* Retrieves an assistant document based on the provided ID.
|
|
*
|
|
* @param {Object} searchParams - The search parameters to find the assistant to update.
|
|
* @param {string} searchParams.assistant_id - The ID of the assistant to update.
|
|
* @param {string} searchParams.user - The user ID of the assistant's author.
|
|
* @returns {Promise<Object|null>} The assistant document as a plain object, or null if not found.
|
|
*/
|
|
const getAssistant = async (searchParams) => await Assistant.findOne(searchParams).lean();
|
|
|
|
/**
|
|
* Retrieves all assistants that match the given search parameters.
|
|
*
|
|
* @param {Object} searchParams - The search parameters to find matching assistants.
|
|
* @returns {Promise<Array<Object>>} A promise that resolves to an array of action documents as plain objects.
|
|
*/
|
|
const getAssistants = async (searchParams) => {
|
|
return await Assistant.find(searchParams).lean();
|
|
};
|
|
|
|
module.exports = {
|
|
updateAssistant,
|
|
getAssistants,
|
|
getAssistant,
|
|
};
|