This commit is contained in:
Barış Soner Uşaklı
2019-02-05 15:27:41 -05:00
parent cd1209906d
commit a2f08e7da2

View File

@@ -325,13 +325,9 @@ SocketGroups.cover.update = function (socket, data, callback) {
async.waterfall([ async.waterfall([
function (next) { function (next) {
groups.ownership.isOwner(socket.uid, data.groupName, next); canModifyGroup(socket.uid, data.groupName, next);
}, },
function (isOwner, next) { function (next) {
if (!isOwner) {
return next(new Error('[[error:no-privileges]]'));
}
groups.updateCover(socket.uid, data, next); groups.updateCover(socket.uid, data, next);
}, },
], callback); ], callback);
@@ -344,14 +340,27 @@ SocketGroups.cover.remove = function (socket, data, callback) {
async.waterfall([ async.waterfall([
function (next) { function (next) {
groups.ownership.isOwner(socket.uid, data.groupName, next); canModifyGroup(socket.uid, data.groupName, next);
}, },
function (isOwner, next) { function (next) {
if (!isOwner) {
return next(new Error('[[error:no-privileges]]'));
}
groups.removeCover(data, next); groups.removeCover(data, next);
}, },
], callback); ], callback);
}; };
function canModifyGroup(uid, groupName, callback) {
async.waterfall([
function (next) {
async.parallel({
isOwner: async.apply(groups.ownership.isOwner, uid, groupName),
isAdminOrGlobalMod: async.apply(user.isAdminOrGlobalMod, uid),
}, next);
},
function (results, next) {
if (!results.isOwner && !results.isAdminOrGlobalMod) {
return next(new Error('[[error:no-privileges]]'));
}
next();
},
], callback);
}