'use strict'; const { Roles, Accounts } = require(__dirname+'/../../db/') , redis = require(__dirname+'/../../lib/redis/redis.js') , dynamicResponse = require(__dirname+'/../../lib/misc/dynamic.js') , roleManager = require(__dirname+'/../../lib/permission/rolemanager.js') , Permission = require(__dirname+'/../../lib/permission/permission.js'); module.exports = async (req, res) => { let rolePermissions = new Permission(res.locals.editingRole.permissions); rolePermissions.handleBody(req.body, res.locals.permissions); // rolePermissions.applyInheritance(); const existingRoleName = roleManager.roleNameMap[rolePermissions.base64]; if (existingRoleName) { return dynamicResponse(req, res, 409, 'message', { 'title': 'Conflict', 'error': `Another role already exists with those same permissions: "${existingRoleName}"`, 'redirect': req.headers.referer || '/globalmanage/roles.html', }); } const updated = await Roles.updateOne(req.body.roleid, rolePermissions).then(r => r.matchedCount); if (updated === 0) { return dynamicResponse(req, res, 400, 'message', { 'title': 'Bad request', 'error': 'Role does not exist', 'redirect': req.headers.referer || '/globalmanage/roles.html', }); } const oldPermissions = new Permission(res.locals.editingRole.permissions); await Accounts.setNewRolePermissions(oldPermissions, rolePermissions); redis.redisPublisher.publish('roles', null); return dynamicResponse(req, res, 200, 'message', { 'title': res.locals.__('Success'), 'message': 'Edited role', 'redirect': `/globalmanage/editrole/${req.body.roleid}.html`, }); };