mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-12-21 16:00:26 +01:00
added new privilege "find", added guest meta group, closed #1282
This commit is contained in:
@@ -78,8 +78,8 @@ Controllers.home = function(req, res, next) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async.filter(data.categories, function (category, next) {
|
async.filter(data.categories, function (category, next) {
|
||||||
privileges.categories.canRead(category.cid, uid, function(err, canRead) {
|
privileges.categories.can('find', category.cid, uid, function(err, findable) {
|
||||||
next(!err && canRead);
|
next(!err && findable);
|
||||||
});
|
});
|
||||||
}, function(visibleCategories) {
|
}, function(visibleCategories) {
|
||||||
data.categories = visibleCategories;
|
data.categories = visibleCategories;
|
||||||
|
|||||||
@@ -44,6 +44,20 @@ module.exports = function(privileges) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
privileges.categories.can = function(privilege, cid, uid, callback) {
|
||||||
|
helpers.some([
|
||||||
|
function(next) {
|
||||||
|
helpers.allowedTo(privilege, uid, cid, next);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
user.isModerator(uid, cid, next);
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
user.isAdministrator(uid, next);
|
||||||
|
}
|
||||||
|
], callback);
|
||||||
|
};
|
||||||
|
|
||||||
privileges.categories.canRead = function(cid, uid, callback) {
|
privileges.categories.canRead = function(cid, uid, callback) {
|
||||||
helpers.some([
|
helpers.some([
|
||||||
function(next) {
|
function(next) {
|
||||||
@@ -80,6 +94,7 @@ module.exports = function(privileges) {
|
|||||||
|
|
||||||
privileges.categories.userPrivileges = function(cid, uid, callback) {
|
privileges.categories.userPrivileges = function(cid, uid, callback) {
|
||||||
async.parallel({
|
async.parallel({
|
||||||
|
find: async.apply(helpers.isMember, groups.isMember, 'cid:' + cid + ':privileges:find', uid),
|
||||||
read: function(next) {
|
read: function(next) {
|
||||||
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:read', uid, next);
|
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:read', uid, next);
|
||||||
},
|
},
|
||||||
@@ -97,6 +112,7 @@ module.exports = function(privileges) {
|
|||||||
|
|
||||||
privileges.categories.groupPrivileges = function(cid, groupName, callback) {
|
privileges.categories.groupPrivileges = function(cid, groupName, callback) {
|
||||||
async.parallel({
|
async.parallel({
|
||||||
|
'groups:find': async.apply(helpers.isMember, groups.isMember, 'cid:' + cid + ':privileges:groups:find', groupName),
|
||||||
'groups:read': function(next) {
|
'groups:read': function(next) {
|
||||||
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:groups:read', groupName, function(err, isMember){
|
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:groups:read', groupName, function(err, isMember){
|
||||||
next(err, !!isMember);
|
next(err, !!isMember);
|
||||||
|
|||||||
@@ -30,13 +30,31 @@ helpers.allowedTo = function(privilege, uid, cid, callback) {
|
|||||||
return callback(null, false);
|
return callback(null, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Guests handling
|
||||||
|
if (parseInt(uid, 10) === 0) {
|
||||||
|
return async.parallel([
|
||||||
|
function(next) {
|
||||||
|
groups.exists('cid:' + cid + ':privileges:' + privilege, function(err, exists) {
|
||||||
|
next(err, !err ? !exists : false);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:groups:' + privilege, 'guests', function(err, isMember) {
|
||||||
|
next(err, privilege !== 'find' ? isMember : isMember !== false);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
], function(err, results) {
|
||||||
|
callback(err, results[0] && results[1]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
async.parallel({
|
async.parallel({
|
||||||
hasUserPrivilege: function(next) {
|
hasUserPrivilege: function(next) {
|
||||||
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:' + privilege, uid, next);
|
helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:' + privilege, uid, next);
|
||||||
},
|
},
|
||||||
hasGroupPrivilege: function(next) {
|
hasGroupPrivilege: function(next) {
|
||||||
helpers.isMember(groups.isMemberOfGroupList, 'cid:' + cid + ':privileges:groups:' + privilege, uid, next);
|
helpers.isMember(groups.isMemberOfGroupList, 'cid:' + cid + ':privileges:groups:' + privilege, uid, next);
|
||||||
},
|
}
|
||||||
}, function(err, results) {
|
}, function(err, results) {
|
||||||
if (err) {
|
if (err) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ Categories.setPrivilege = function(socket, data, callback) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
Categories.getPrivilegeSettings = function(socket, cid, callback) {
|
Categories.getPrivilegeSettings = function(socket, cid, callback) {
|
||||||
var privileges = ['read', 'topics:create', 'topics:reply', 'mods'];
|
var privileges = ['find', 'read', 'topics:create', 'topics:reply', 'mods'];
|
||||||
|
|
||||||
async.reduce(privileges, [], function(members, privilege, next) {
|
async.reduce(privileges, [], function(members, privilege, next) {
|
||||||
groups.get('cid:' + cid + ':privileges:' + privilege, { expand: true }, function(err, groupObj) {
|
groups.get('cid:' + cid + ':privileges:' + privilege, { expand: true }, function(err, groupObj) {
|
||||||
|
|||||||
Reference in New Issue
Block a user