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} 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} 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>} 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} Resolves when the assistant has been successfully deleted. */ const deleteAssistant = async (searchParams) => { return await Assistant.findOneAndDelete(searchParams); }; module.exports = { updateAssistantDoc, deleteAssistant, getAssistants, getAssistant, };