mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
55 lines
1.8 KiB
JavaScript
55 lines
1.8 KiB
JavaScript
|
|
const { getPrompt } = require('~/models/Prompt');
|
||
|
|
const { canAccessResource } = require('./canAccessResource');
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Prompt to PromptGroup ID resolver function
|
||
|
|
* Resolves prompt ID to its parent promptGroup ID
|
||
|
|
*
|
||
|
|
* @param {string} promptId - Prompt ID from route parameter
|
||
|
|
* @returns {Promise<Object|null>} Object with promptGroup's _id field, or null if not found
|
||
|
|
*/
|
||
|
|
const resolvePromptToGroupId = async (promptId) => {
|
||
|
|
const prompt = await getPrompt({ _id: promptId });
|
||
|
|
if (!prompt || !prompt.groupId) {
|
||
|
|
return null;
|
||
|
|
}
|
||
|
|
// Return an object with _id that matches the promptGroup ID
|
||
|
|
return { _id: prompt.groupId };
|
||
|
|
};
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Middleware factory that checks promptGroup permissions when accessing individual prompts.
|
||
|
|
* This allows permission management at the promptGroup level while still supporting
|
||
|
|
* individual prompt access patterns.
|
||
|
|
*
|
||
|
|
* @param {Object} options - Configuration options
|
||
|
|
* @param {number} options.requiredPermission - The permission bit required (1=view, 2=edit, 4=delete, 8=share)
|
||
|
|
* @param {string} [options.resourceIdParam='promptId'] - The name of the route parameter containing the prompt ID
|
||
|
|
* @returns {Function} Express middleware function
|
||
|
|
*
|
||
|
|
* @example
|
||
|
|
* // Check promptGroup permissions when viewing a prompt
|
||
|
|
* router.get('/prompts/:promptId',
|
||
|
|
* canAccessPromptViaGroup({ requiredPermission: 1 }),
|
||
|
|
* getPrompt
|
||
|
|
* );
|
||
|
|
*/
|
||
|
|
const canAccessPromptViaGroup = (options) => {
|
||
|
|
const { requiredPermission, resourceIdParam = 'promptId' } = options;
|
||
|
|
|
||
|
|
if (!requiredPermission || typeof requiredPermission !== 'number') {
|
||
|
|
throw new Error('canAccessPromptViaGroup: requiredPermission is required and must be a number');
|
||
|
|
}
|
||
|
|
|
||
|
|
return canAccessResource({
|
||
|
|
resourceType: 'promptGroup',
|
||
|
|
requiredPermission,
|
||
|
|
resourceIdParam,
|
||
|
|
idResolver: resolvePromptToGroupId,
|
||
|
|
});
|
||
|
|
};
|
||
|
|
|
||
|
|
module.exports = {
|
||
|
|
canAccessPromptViaGroup,
|
||
|
|
};
|