2026-03-24 23:40:12 -07:00
|
|
|
const express = require('express');
|
|
|
|
|
const { createAdminRolesHandlers } = require('@librechat/api');
|
|
|
|
|
const { SystemCapabilities } = require('@librechat/data-schemas');
|
|
|
|
|
const { requireCapability } = require('~/server/middleware/roles/capabilities');
|
|
|
|
|
const { requireJwtAuth } = require('~/server/middleware');
|
|
|
|
|
const db = require('~/models');
|
|
|
|
|
|
|
|
|
|
const router = express.Router();
|
|
|
|
|
|
|
|
|
|
const requireAdminAccess = requireCapability(SystemCapabilities.ACCESS_ADMIN);
|
|
|
|
|
const requireReadRoles = requireCapability(SystemCapabilities.READ_ROLES);
|
|
|
|
|
const requireManageRoles = requireCapability(SystemCapabilities.MANAGE_ROLES);
|
|
|
|
|
|
|
|
|
|
const handlers = createAdminRolesHandlers({
|
|
|
|
|
listRoles: db.listRoles,
|
2026-03-26 17:24:01 -07:00
|
|
|
countRoles: db.countRoles,
|
2026-03-24 23:40:12 -07:00
|
|
|
getRoleByName: db.getRoleByName,
|
2026-03-25 08:56:38 -07:00
|
|
|
createRoleByName: db.createRoleByName,
|
2026-03-24 23:40:12 -07:00
|
|
|
updateRoleByName: db.updateRoleByName,
|
|
|
|
|
updateAccessPermissions: db.updateAccessPermissions,
|
2026-03-25 08:56:38 -07:00
|
|
|
deleteRoleByName: db.deleteRoleByName,
|
2026-03-24 23:40:12 -07:00
|
|
|
findUser: db.findUser,
|
|
|
|
|
updateUser: db.updateUser,
|
2026-03-26 15:30:33 -07:00
|
|
|
updateUsersByRole: db.updateUsersByRole,
|
2026-03-24 23:54:32 -07:00
|
|
|
listUsersByRole: db.listUsersByRole,
|
2026-03-26 15:30:33 -07:00
|
|
|
countUsersByRole: db.countUsersByRole,
|
2026-03-24 23:40:12 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
router.use(requireJwtAuth, requireAdminAccess);
|
|
|
|
|
|
|
|
|
|
router.get('/', requireReadRoles, handlers.listRoles);
|
|
|
|
|
router.post('/', requireManageRoles, handlers.createRole);
|
|
|
|
|
router.get('/:name', requireReadRoles, handlers.getRole);
|
|
|
|
|
router.patch('/:name', requireManageRoles, handlers.updateRole);
|
|
|
|
|
router.delete('/:name', requireManageRoles, handlers.deleteRole);
|
|
|
|
|
router.patch('/:name/permissions', requireManageRoles, handlers.updateRolePermissions);
|
|
|
|
|
router.get('/:name/members', requireReadRoles, handlers.getRoleMembers);
|
|
|
|
|
router.post('/:name/members', requireManageRoles, handlers.addRoleMember);
|
|
|
|
|
router.delete('/:name/members/:userId', requireManageRoles, handlers.removeRoleMember);
|
|
|
|
|
|
|
|
|
|
module.exports = router;
|