| const { Assistant } = require('~/db/models'); | |
| /** | |
| * 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, | |
| }; | |