moved isAdminOrMod check out of getTopicsByTids

v1.18.x
barisusakli
parent a75727bbbd
commit 8e114c2093

@ -2,48 +2,57 @@
var async = require('async'), var async = require('async'),
db = require('../database'), db = require('../database'),
user = require('../user'),
topics = require('../topics'), topics = require('../topics'),
plugins = require('../plugins'); plugins = require('../plugins');
module.exports = function(Categories) { module.exports = function(Categories) {
Categories.getCategoryTopics = function(data, callback) { Categories.getCategoryTopics = function(data, callback) {
var tids; async.parallel({
async.waterfall([ isAdmin: function(next) {
async.apply(plugins.fireHook, 'filter:category.topics.prepare', data), user.isAdministrator(data.uid, next);
function(data, next) {
Categories.getTopicIds(data.targetUid ? 'cid:' + data.cid + ':uid:' + data.targetUid + ':tids' : 'cid:' + data.cid + ':tids', data.start, data.stop, next);
}, },
function(topicIds, next) { isModerator: function(next) {
tids = topicIds; user.isModerator(data.uid, data.cid, next);
topics.getTopicsByTids(tids, data.uid, next);
}, },
function(topics, next) { topics: function(next) {
if (!Array.isArray(topics) || !topics.length) { async.waterfall([
return next(null, { function(next) {
topics: [], plugins.fireHook('filter:category.topics.prepare', data, next);
nextStart: 1 },
}); function(data, next) {
} Categories.getTopicIds(data.targetUid ? 'cid:' + data.cid + ':uid:' + data.targetUid + ':tids' : 'cid:' + data.cid + ':tids', data.start, data.stop, next);
},
function(tids, next) {
topics.getTopicsByTids(tids, data.uid, next);
},
function(topics, next) {
if (!Array.isArray(topics) || !topics.length) {
return next(null, []);
}
var indices = {}, for (var i=0; i<topics.length; ++i) {
i = 0; topics[i].index = data.start + i;
for(i=0; i<tids.length; ++i) { }
indices[tids[i]] = data.start + i;
}
for(i=0; i<topics.length; ++i) { plugins.fireHook('filter:category.topics.get', {topics: topics, uid: data.uid}, function(err, params) {
topics[i].index = indices[topics[i].tid]; next(null, params.topics);
} });
}
plugins.fireHook('filter:category.topics.get', {topics: topics, uid: data.uid}, function(err, params) { ], next);
next(null, {
topics: params.topics,
nextStart: data.stop + 1
});
});
} }
], callback); }, function(err, results) {
if (err) {
return callback(err);
}
var isAdminOrMod = results.isAdmin || results.isModerator;
results.topics = results.topics.filter(function(topic) {
return (!topic.deleted || isAdminOrMod || topic.isOwner);
});
callback(null, {topics: results.topics, nextStart: data.stop + 1});
});
}; };
Categories.getTopicIds = function(set, start, stop, callback) { Categories.getTopicIds = function(set, start, stop, callback) {

@ -22,7 +22,7 @@ tagsController.getTag = function(req, res, next) {
return res.render('tag', {topics: [], tag: tag}); return res.render('tag', {topics: [], tag: tag});
} }
topics.getTopics(tids, uid, function(err, data) { topics.getTopics(tids, uid, function(err, topics) {
if (err) { if (err) {
return next(err); return next(err);
} }
@ -42,9 +42,7 @@ tagsController.getTag = function(req, res, next) {
} }
]; ];
data.tag = tag; res.render('tag', {topics: topics, tag: tag, nextStart: end + 1});
data.nextStart = end + 1;
res.render('tag', data);
}); });
}); });
}; };

@ -143,28 +143,6 @@ module.exports = function(privileges) {
}, callback); }, callback);
}; };
privileges.categories.isAdminOrMod = function(cids, uid, callback) {
async.parallel({
isModerators: function(next) {
user.isModerator(uid, cids, next);
},
isAdmin: function(next) {
user.isAdministrator(uid, next);
}
}, function(err, results) {
if (err) {
return callback(err);
}
var returnData = new Array(cids.length);
for (var i=0; i<cids.length; ++i) {
returnData[i] = results.isAdmin || results.isModerators[i];
}
callback(null, returnData);
});
};
privileges.categories.canMoveAllTopics = function(currentCid, targetCid, uid, callback) { privileges.categories.canMoveAllTopics = function(currentCid, targetCid, uid, callback) {
async.parallel({ async.parallel({
isAdministrator: function(next) { isAdministrator: function(next) {

@ -99,7 +99,7 @@ var async = require('async'),
Topics.getCategoryData = function(tid, callback) { Topics.getCategoryData = function(tid, callback) {
Topics.getTopicField(tid, 'cid', function(err, cid) { Topics.getTopicField(tid, 'cid', function(err, cid) {
if(err) { if (err) {
callback(err); callback(err);
} }
@ -107,43 +107,29 @@ var async = require('async'),
}); });
}; };
Topics.getTopics = function(tids, uid, callback) { Topics.getTopicsFromSet = function(set, uid, start, end, callback) {
var returnTopics = { async.waterfall([
topics: [], function(next) {
nextStart: 0 db.getSortedSetRevRange(set, start, end, next);
}; },
function(tids, next) {
privileges.topics.filter('read', tids, uid, function(err, tids) { Topics.getTopics(tids, uid, next);
if (err) { },
return callback(err); function(topics, next) {
next(null, {topics: topics, nextStart: end + 1});
} }
], callback);
Topics.getTopicsByTids(tids, uid, function(err, topicData) {
if (err) {
return callback(err);
}
returnTopics.topics = topicData;
callback(null, returnTopics);
});
});
}; };
Topics.getTopicsFromSet = function(set, uid, start, end, callback) { Topics.getTopics = function(tids, uid, callback) {
db.getSortedSetRevRange(set, start, end, function(err, tids) { async.waterfall([
if (err) { function(next) {
return callback(err); privileges.topics.filter('read', tids, uid, next);
},
function(tids, next) {
Topics.getTopicsByTids(tids, uid, next);
} }
], callback);
Topics.getTopics(tids, uid, function(err, data) {
if (err) {
return callback(err);
}
data.nextStart = end + 1;
callback(null, data);
});
});
}; };
Topics.getTopicsByTids = function(tids, uid, callback) { Topics.getTopicsByTids = function(tids, uid, callback) {
@ -169,7 +155,7 @@ var async = require('async'),
async.parallel({ async.parallel({
teasers: function(next) { teasers: function(next) {
Topics.getTeasers(tids, uid, next); Topics.getTeasers(tids, next);
}, },
users: function(next) { users: function(next) {
user.getMultipleUserFields(uids, ['uid', 'username', 'userslug', 'picture'], next); user.getMultipleUserFields(uids, ['uid', 'username', 'userslug', 'picture'], next);
@ -180,9 +166,6 @@ var async = require('async'),
hasRead: function(next) { hasRead: function(next) {
Topics.hasReadTopics(tids, uid, next); Topics.hasReadTopics(tids, uid, next);
}, },
isAdminOrMod: function(next) {
privileges.categories.isAdminOrMod(cids, uid, next);
},
tags: function(next) { tags: function(next) {
Topics.getTopicsTagsObjects(tids, next); Topics.getTopicsTagsObjects(tids, next);
} }
@ -193,30 +176,25 @@ var async = require('async'),
var users = _.object(uids, results.users); var users = _.object(uids, results.users);
var categories = _.object(cids, results.categories); var categories = _.object(cids, results.categories);
var isAdminOrMod = {};
cids.forEach(function(cid, index) {
isAdminOrMod[cid] = results.isAdminOrMod[index];
});
for (var i=0; i<topics.length; ++i) { for (var i=0; i<topics.length; ++i) {
if (topics[i]) { if (topics[i]) {
topics[i].category = categories[topics[i].cid] || {}; topics[i].category = categories[topics[i].cid];
topics[i].user = users[topics[i].uid]; topics[i].user = users[topics[i].uid];
topics[i].teaser = results.teasers[i]; topics[i].teaser = results.teasers[i];
topics[i].tags = results.tags[i]; topics[i].tags = results.tags[i];
topics[i].isOwner = parseInt(topics[i].uid, 10) === parseInt(uid, 10);
topics[i].pinned = parseInt(topics[i].pinned, 10) === 1; topics[i].pinned = parseInt(topics[i].pinned, 10) === 1;
topics[i].locked = parseInt(topics[i].locked, 10) === 1; topics[i].locked = parseInt(topics[i].locked, 10) === 1;
topics[i].deleted = parseInt(topics[i].deleted, 10) === 1; topics[i].deleted = parseInt(topics[i].deleted, 10) === 1;
topics[i].unread = !(results.hasRead[i] && parseInt(uid, 10) !== 0); topics[i].unread = !results.hasRead[i];
topics[i].unreplied = parseInt(topics[i].postcount, 10) <= 1; topics[i].unreplied = parseInt(topics[i].postcount, 10) <= 1;
} }
} }
topics = topics.filter(function(topic) { topics = topics.filter(function(topic) {
return topic && !topic.category.disabled && return topic && topic.category && !topic.category.disabled;
(!topic.deleted || (topic.deleted && isAdminOrMod[topic.cid]) ||
parseInt(topic.uid, 10) === parseInt(uid, 10));
}); });
plugins.fireHook('filter:topics.get', {topics: topics, uid: uid}, function(err, topicData) { plugins.fireHook('filter:topics.get', {topics: topics, uid: uid}, function(err, topicData) {

@ -20,20 +20,17 @@ module.exports = function(Topics) {
}; };
Topics.getLatestTopics = function(uid, start, end, term, callback) { Topics.getLatestTopics = function(uid, start, end, term, callback) {
Topics.getLatestTids(start, end, term, function(err, tids) { async.waterfall([
if (err) { function (next) {
return callback(err); Topics.getLatestTids(start, end, term, next);
},
function(tids, next) {
Topics.getTopics(tids, uid, next);
},
function(topics, next) {
next(null, {topics: topics, nextStart: end + 1});
} }
], callback);
Topics.getTopics(tids, uid, function(err, data) {
if (err) {
return callback(err);
}
data.nextStart = end + 1;
callback(null, data);
});
});
}; };
Topics.getLatestTids = function(start, end, term, callback) { Topics.getLatestTids = function(start, end, term, callback) {

@ -12,7 +12,7 @@ var async = require('async'),
module.exports = function(Topics) { module.exports = function(Topics) {
Topics.getTeasers = function(tids, uid, callback) { Topics.getTeasers = function(tids, callback) {
if (!Array.isArray(tids) || !tids.length) { if (!Array.isArray(tids) || !tids.length) {
return callback(null, []); return callback(null, []);
} }
@ -85,7 +85,7 @@ module.exports = function(Topics) {
}); });
}; };
Topics.getTeaser = function(tid, uid, callback) { Topics.getTeaser = function(tid, callback) {
Topics.getLatestUndeletedPid(tid, function(err, pid) { Topics.getLatestUndeletedPid(tid, function(err, pid) {
if (err || !pid) { if (err || !pid) {
return callback(err); return callback(err);
@ -109,8 +109,8 @@ module.exports = function(Topics) {
}); });
}); });
}, },
postIndex: function(next) { postCount: function(next) {
posts.getPidIndex(pid, uid, next); Topics.getTopicField(tid, 'post_count', next);
} }
}, function(err, results) { }, function(err, results) {
if (err) { if (err) {
@ -118,7 +118,7 @@ module.exports = function(Topics) {
} }
results.postData.timestamp = utils.toISOString(results.postData.timestamp); results.postData.timestamp = utils.toISOString(results.postData.timestamp);
results.postData.index = results.postIndex; results.postData.index = results.postCount;
callback(null, results.postData); callback(null, results.postData);
}); });

Loading…
Cancel
Save