const { Action } = require('~/db/models'); /** * Update an action with new data without overwriting existing properties, * or create a new action if it doesn't exist. * * @param {Object} searchParams - The search parameters to find the action to update. * @param {string} searchParams.action_id - The ID of the action to update. * @param {string} searchParams.user - The user ID of the action's author. * @param {Object} updateData - An object containing the properties to update. * @returns {Promise} The updated or newly created action document as a plain object. */ const updateAction = async (searchParams, updateData) => { const options = { new: true, upsert: true }; return await Action.findOneAndUpdate(searchParams, updateData, options).lean(); }; /** * Retrieves all actions that match the given search parameters. * * @param {Object} searchParams - The search parameters to find matching actions. * @param {boolean} includeSensitive - Flag to include sensitive data in the metadata. * @returns {Promise>} A promise that resolves to an array of action documents as plain objects. */ const getActions = async (searchParams, includeSensitive = false) => { const actions = await Action.find(searchParams).lean(); if (!includeSensitive) { for (let i = 0; i < actions.length; i++) { const metadata = actions[i].metadata; if (!metadata) { continue; } const sensitiveFields = ['api_key', 'oauth_client_id', 'oauth_client_secret']; for (let field of sensitiveFields) { if (metadata[field]) { delete metadata[field]; } } } } return actions; }; /** * Deletes an action by params. * * @param {Object} searchParams - The search parameters to find the action to delete. * @param {string} searchParams.action_id - The ID of the action to delete. * @param {string} searchParams.user - The user ID of the action's author. * @returns {Promise} A promise that resolves to the deleted action document as a plain object, or null if no document was found. */ const deleteAction = async (searchParams) => { return await Action.findOneAndDelete(searchParams).lean(); }; /** * Deletes actions by params. * * @param {Object} searchParams - The search parameters to find the actions to delete. * @param {string} searchParams.action_id - The ID of the action(s) to delete. * @param {string} searchParams.user - The user ID of the action's author. * @returns {Promise} A promise that resolves to the number of deleted action documents. */ const deleteActions = async (searchParams) => { const result = await Action.deleteMany(searchParams); return result.deletedCount; }; module.exports = { getActions, updateAction, deleteAction, deleteActions, };