mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 11:35:55 +01:00
fixed #744
This commit is contained in:
@@ -26,27 +26,18 @@ var winston = require('winston'),
|
|||||||
}
|
}
|
||||||
|
|
||||||
PostTools.privileges = function(pid, uid, callback) {
|
PostTools.privileges = function(pid, uid, callback) {
|
||||||
if(parseInt(uid, 10) === 0) {
|
async.parallel({
|
||||||
callback({
|
topicPrivs: function(next) {
|
||||||
editable: false,
|
|
||||||
view_deleted: false
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
function getThreadPrivileges(next) {
|
|
||||||
posts.getPostField(pid, 'tid', function(err, tid) {
|
posts.getPostField(pid, 'tid', function(err, tid) {
|
||||||
threadTools.privileges(tid, uid, next);
|
threadTools.privileges(tid, uid, next);
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
|
isOwner: function(next) {
|
||||||
function isOwnPost(next) {
|
|
||||||
posts.getPostField(pid, 'uid', function(err, author) {
|
posts.getPostField(pid, 'uid', function(err, author) {
|
||||||
next(null, parseInt(author, 10) === parseInt(uid, 10));
|
next(null, parseInt(author, 10) === parseInt(uid, 10));
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
|
hasEnoughRep: function(next) {
|
||||||
function hasEnoughRep(next) {
|
|
||||||
if (parseInt(meta.config['privileges:disabled'], 10)) {
|
if (parseInt(meta.config['privileges:disabled'], 10)) {
|
||||||
return next(null, false);
|
return next(null, false);
|
||||||
} else {
|
} else {
|
||||||
@@ -58,11 +49,12 @@ var winston = require('winston'),
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// [getThreadPrivileges, isOwnPost, hasEnoughRep]
|
||||||
async.parallel([getThreadPrivileges, isOwnPost, hasEnoughRep], function(err, results) {
|
}, function(err, results) {
|
||||||
callback({
|
callback({
|
||||||
editable: results[0].editable || results[1] || results[2],
|
read: results.topicPrivs.read,
|
||||||
view_deleted: results[0].view_deleted || results[1] || results[2]
|
editable: results.topicPrivs.editable || results.isOwner || results.hasEnoughRep,
|
||||||
|
view_deleted: results.topicPrivs.view_deleted || results.isOwner || results.hasEnoughRep
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -426,6 +426,11 @@ var db = require('./database'),
|
|||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async.filter(pids, function(pid, next) {
|
||||||
|
postTools.privileges(pid, 0, function(privileges) {
|
||||||
|
next(privileges.read);
|
||||||
|
});
|
||||||
|
}, function(pids) {
|
||||||
if (pids && pids.length) {
|
if (pids && pids.length) {
|
||||||
plugins.fireHook('filter:post.getTopic', pids, function(err, posts) {
|
plugins.fireHook('filter:post.getTopic', pids, function(err, posts) {
|
||||||
if(err) {
|
if(err) {
|
||||||
@@ -445,6 +450,7 @@ var db = require('./database'),
|
|||||||
callback(null, []);
|
callback(null, []);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user