mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-29 18:16:17 +01:00
fix: if editing password is disabled in ACP, prevent direct access via route/socket (related: #7576)
This commit is contained in:
@@ -98,8 +98,8 @@ function renderRoute(name, req, res, next) {
|
||||
return next();
|
||||
}
|
||||
|
||||
if ((name === 'username' && userData['username:disableEdit']) || (name === 'email' && userData['email:disableEdit'])) {
|
||||
return next();
|
||||
if (meta.config[name + ':disableEdit'] && !userData.isAdmin) {
|
||||
return helpers.notAllowed(req, res);
|
||||
}
|
||||
|
||||
if (name === 'password') {
|
||||
|
||||
@@ -319,11 +319,18 @@ module.exports = function (User) {
|
||||
User.isPasswordValid(data.newPassword, next);
|
||||
},
|
||||
function (next) {
|
||||
if (parseInt(uid, 10) !== parseInt(data.uid, 10)) {
|
||||
User.isAdministrator(uid, next);
|
||||
} else {
|
||||
User.isPasswordCorrect(uid, data.currentPassword, data.ip, next);
|
||||
User.isAdministrator(uid, next);
|
||||
},
|
||||
function (isAdmin, next) {
|
||||
if (meta.config['password:disableEdit'] && !isAdmin) {
|
||||
return next(new Error('[[error:no-privileges]]'));
|
||||
}
|
||||
|
||||
if (isAdmin && parseInt(uid, 10) !== parseInt(data.uid, 10)) {
|
||||
return next(null, true);
|
||||
}
|
||||
|
||||
User.isPasswordCorrect(uid, data.currentPassword, data.ip, next);
|
||||
},
|
||||
function (isAdminOrPasswordMatch, next) {
|
||||
if (!isAdminOrPasswordMatch) {
|
||||
|
||||
Reference in New Issue
Block a user