mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
62 lines
2 KiB
JavaScript
62 lines
2 KiB
JavaScript
|
|
const { ResourceType } = require('librechat-data-provider');
|
||
|
|
const { canAccessResource } = require('./canAccessResource');
|
||
|
|
const { findMCPServerById } = require('~/models');
|
||
|
|
|
||
|
|
/**
|
||
|
|
* MCP Server ID resolver function
|
||
|
|
* Resolves custom MCP server ID (e.g., "mcp_abc123") to MongoDB ObjectId
|
||
|
|
*
|
||
|
|
* @param {string} mcpServerCustomId - Custom MCP server ID from route parameter
|
||
|
|
* @returns {Promise<Object|null>} MCP server document with _id field, or null if not found
|
||
|
|
*/
|
||
|
|
const resolveMCPServerId = async (mcpServerCustomId) => {
|
||
|
|
return await findMCPServerById(mcpServerCustomId);
|
||
|
|
};
|
||
|
|
|
||
|
|
/**
|
||
|
|
* MCP Server-specific middleware factory that creates middleware to check MCP server access permissions.
|
||
|
|
* This middleware extends the generic canAccessResource to handle MCP server custom ID resolution.
|
||
|
|
*
|
||
|
|
* @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='serverName'] - The name of the route parameter containing the MCP server custom ID
|
||
|
|
* @returns {Function} Express middleware function
|
||
|
|
*
|
||
|
|
* @example
|
||
|
|
* // Basic usage for viewing MCP servers
|
||
|
|
* router.get('/servers/:serverName',
|
||
|
|
* canAccessMCPServerResource({ requiredPermission: 1 }),
|
||
|
|
* getMCPServer
|
||
|
|
* );
|
||
|
|
*
|
||
|
|
* @example
|
||
|
|
* // Custom resource ID parameter and edit permission
|
||
|
|
* router.patch('/servers/:id',
|
||
|
|
* canAccessMCPServerResource({
|
||
|
|
* requiredPermission: 2,
|
||
|
|
* resourceIdParam: 'id'
|
||
|
|
* }),
|
||
|
|
* updateMCPServer
|
||
|
|
* );
|
||
|
|
*/
|
||
|
|
const canAccessMCPServerResource = (options) => {
|
||
|
|
const { requiredPermission, resourceIdParam = 'serverName' } = options;
|
||
|
|
|
||
|
|
if (!requiredPermission || typeof requiredPermission !== 'number') {
|
||
|
|
throw new Error(
|
||
|
|
'canAccessMCPServerResource: requiredPermission is required and must be a number',
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
return canAccessResource({
|
||
|
|
resourceType: ResourceType.MCPSERVER,
|
||
|
|
requiredPermission,
|
||
|
|
resourceIdParam,
|
||
|
|
idResolver: resolveMCPServerId,
|
||
|
|
});
|
||
|
|
};
|
||
|
|
|
||
|
|
module.exports = {
|
||
|
|
canAccessMCPServerResource,
|
||
|
|
};
|