mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-19 09:50:15 +01:00
- Removed the export of models from the database connection module to simplify the structure. - Updated various files to import models directly from the new centralized models module. - Ensured consistency across the codebase by replacing mongoose model references with the new import paths.
63 lines
2.5 KiB
JavaScript
63 lines
2.5 KiB
JavaScript
const mongoose = require('mongoose');
|
|
const Assistant = require('~/db/models').Assistant;
|
|
|
|
/**
|
|
* Update an assistant with new data without overwriting existing properties,
|
|
* or create a new assistant if it doesn't exist.
|
|
*
|
|
* @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.
|
|
* @returns {Promise<AssistantDocument>} The updated or newly created assistant document as a plain object.
|
|
*/
|
|
const updateAssistantDoc = async (searchParams, updateData) => {
|
|
const options = { new: true, upsert: true };
|
|
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<AssistantDocument|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.
|
|
* @param {Object} [select] - Optional. Specifies which document fields to include or exclude.
|
|
* @returns {Promise<Array<AssistantDocument>>} A promise that resolves to an array of assistant documents as plain objects.
|
|
*/
|
|
const getAssistants = async (searchParams, select = null) => {
|
|
let query = Assistant.find(searchParams);
|
|
|
|
if (select) {
|
|
query = query.select(select);
|
|
}
|
|
|
|
return await query.lean();
|
|
};
|
|
|
|
/**
|
|
* Deletes an assistant based on the provided ID.
|
|
*
|
|
* @param {Object} searchParams - The search parameters to find the assistant to delete.
|
|
* @param {string} searchParams.assistant_id - The ID of the assistant to delete.
|
|
* @param {string} searchParams.user - The user ID of the assistant's author.
|
|
* @returns {Promise<void>} Resolves when the assistant has been successfully deleted.
|
|
*/
|
|
const deleteAssistant = async (searchParams) => {
|
|
return await Assistant.findOneAndDelete(searchParams);
|
|
};
|
|
|
|
module.exports = {
|
|
updateAssistantDoc,
|
|
deleteAssistant,
|
|
getAssistants,
|
|
getAssistant,
|
|
};
|