diff --git a/meshuser.js b/meshuser.js index a98e1217..5621b5f5 100644 --- a/meshuser.js +++ b/meshuser.js @@ -1584,7 +1584,13 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use if (command.resetNextLogin === true) { chguser.passchange = -1; } if ((command.consent != null) && (typeof command.consent == 'number')) { if (command.consent == 0) { delete chguser.consent; } else { chguser.consent = command.consent; } change = 1; } if ((command.phone != null) && (typeof command.phone == 'string') && ((command.phone == '') || isPhoneNumber(command.phone))) { if (command.phone == '') { delete chguser.phone; } else { chguser.phone = command.phone; } change = 1; } - if ((command.flags != null) && (typeof command.flags == 'number')) { if (command.flags == 0) { delete chguser.flags; } else { chguser.flags = command.flags; } change = 1; } // Flags: 1 = Account Image, 2 = Session Recording + if ((command.flags != null) && (typeof command.flags == 'number')) { + // Flags: 1 = Account Image, 2 = Session Recording + if ((command.flags == 0) && (chguser.flags != null)) { delete chguser.flags; change = 1; } else { if (command.flags !== chguser.flags) { chguser.flags = command.flags; change = 1; } } + } + if ((command.removeRights != null) && (typeof command.removeRights == 'number')) { + if ((command.removeRights == 0) && (chguser.removeRights != null)) { delete chguser.removeRights; change = 1; } else { if (command.removeRights !== chguser.removeRights) { chguser.removeRights = command.removeRights; change = 1; } } + } // Site admins can change any server rights, user managers can only change AccountLock, NoMeshCmd and NoNewGroups if (common.validateInt(command.siteadmin) && (chguser._id !== user._id) && (chguser.siteadmin != command.siteadmin)) { // We can't change our own siteadmin permissions. diff --git a/views/default.handlebars b/views/default.handlebars index b1df5f56..9118790f 100644 --- a/views/default.handlebars +++ b/views/default.handlebars @@ -14052,15 +14052,18 @@ } // Display features - if (serverinfo.usersSessionRecording == 1) { - var userFeatures = []; - if (user.flags) { - if ((serverinfo.usersSessionRecording == 1) && (user.flags & 2)) { userFeatures.push("Record Sessions"); } - } - userFeatures = userFeatures.join(', '); - if (userFeatures == '') { userFeatures = '' + "None" + ''; } - x += addDeviceAttribute("Features", addLink(userFeatures, 'p20edituserfeatures()')); + var userFeatures = []; + if ((serverinfo.usersSessionRecording == 1) && (user.flags) && (user.flags & 2)) { userFeatures.push("Record Sessions"); } + if (user.removeRights) { + if ((user.removeRights & 0x00010000) != 0) { userFeatures.push("No Desktop"); } + else if ((user.removeRights & 0x00000100) != 0) { userFeatures.push("Desktop View Only"); } + if ((user.removeRights & 0x00000200) != 0) { userFeatures.push("No Terminal"); } + if ((user.removeRights & 0x00000400) != 0) { userFeatures.push("No Files"); } + if ((user.removeRights & 0x00000010) != 0) { userFeatures.push("No Console"); } } + userFeatures = userFeatures.join(', '); + if (userFeatures == '') { userFeatures = '' + "None" + ''; } + x += addDeviceAttribute("Features", addLink(userFeatures, 'p20edituserfeatures()')); x += addDeviceAttribute("Server Rights", premsg + msg.join(', ') + ' '); if (user.quota) x += addDeviceAttribute("Server Quota", EscapeHtml(parseInt(user.quota) / 1024) + ' k'); @@ -14179,19 +14182,38 @@ function p20edituserfeatures() { if (xxdialogMode) return; var flags = (currentUser.flags)?currentUser.flags:0, x = ''; // Flags: 1 = Account Image, 2 = Session Recording + var removeRights = (currentUser.removeRights)?currentUser.removeRights:0, x = ''; // Remove Device Group Rights if (serverinfo.usersSessionRecording == 1) { - x += '