addm upvotes, downvotes and votes to getPostSummary
v1.18.x
barisusakli 9 years ago
parent 2ce33ba2b0
commit 460ac17eaa

@ -23,25 +23,27 @@ module.exports = function(Posts) {
options.parse = options.hasOwnProperty('parse') ? options.parse : true; options.parse = options.hasOwnProperty('parse') ? options.parse : true;
options.extraFields = options.hasOwnProperty('extraFields') ? options.extraFields : []; options.extraFields = options.hasOwnProperty('extraFields') ? options.extraFields : [];
var fields = ['pid', 'tid', 'content', 'uid', 'timestamp', 'deleted'].concat(options.extraFields); var fields = ['pid', 'tid', 'content', 'uid', 'timestamp', 'deleted', 'upvotes', 'downvotes'].concat(options.extraFields);
Posts.getPostsFields(pids, fields, function(err, posts) { var posts;
if (err) { async.waterfall([
return callback(err); function(next) {
} Posts.getPostsFields(pids, fields, next);
},
function(_posts, next) {
posts = _posts.filter(Boolean);
posts = posts.filter(Boolean); var uids = [];
var topicKeys = [];
var uids = [], topicKeys = []; posts.forEach(function(post, i) {
for(var i=0; i<posts.length; ++i) {
if (uids.indexOf(posts[i].uid) === -1) { if (uids.indexOf(posts[i].uid) === -1) {
uids.push(posts[i].uid); uids.push(posts[i].uid);
} }
if (topicKeys.indexOf('topic:' + posts[i].tid) === -1) { if (topicKeys.indexOf('topic:' + posts[i].tid) === -1) {
topicKeys.push('topic:' + posts[i].tid); topicKeys.push('topic:' + posts[i].tid);
} }
} });
async.parallel({ async.parallel({
users: function(next) { users: function(next) {
user.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture'], next); user.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture'], next);
@ -52,36 +54,47 @@ module.exports = function(Posts) {
indices: function(next) { indices: function(next) {
Posts.getPostIndices(posts, uid, next); Posts.getPostIndices(posts, uid, next);
} }
}, function(err, results) { }, next);
if (err) { },
return callback(err); function(results, next) {
}
results.users = toObject('uid', results.users); results.users = toObject('uid', results.users);
results.topics = toObject('tid', results.topicsAndCategories.topics); results.topics = toObject('tid', results.topicsAndCategories.topics);
results.categories = toObject('cid', results.topicsAndCategories.categories); results.categories = toObject('cid', results.topicsAndCategories.categories);
for (var i=0; i<posts.length; ++i) { posts.forEach(function(post, i) {
posts[i].index = utils.isNumber(results.indices[i]) ? parseInt(results.indices[i], 10) + 1 : 1; post.index = utils.isNumber(results.indices[i]) ? parseInt(results.indices[i], 10) + 1 : 1;
posts[i].isMainPost = posts[i].index - 1 === 0; post.isMainPost = post.index - 1 === 0;
posts[i].deleted = parseInt(posts[i].deleted, 10) === 1; post.deleted = parseInt(posts[i].deleted, 10) === 1;
} post.upvotes = parseInt(post.upvotes, 10) || 0;
post.downvotes = parseInt(post.downvotes, 10) || 0;
posts = posts.filter(function(post) { post.votes = post.upvotes - post.downvotes;
return results.topics[post.tid];
});
async.map(posts, function(post, next) {
// If the post author isn't represented in the retrieved users' data, then it means they were deleted, assume guest. // If the post author isn't represented in the retrieved users' data, then it means they were deleted, assume guest.
if (!results.users.hasOwnProperty(post.uid)) { if (!results.users.hasOwnProperty(post.uid)) {
post.uid = 0; post.uid = 0;
} }
post.user = results.users[post.uid]; post.user = results.users[post.uid];
post.topic = results.topics[post.tid]; post.topic = results.topics[post.tid];
post.category = results.categories[post.topic.cid]; post.category = results.categories[post.topic.cid];
post.timestampISO = utils.toISOString(post.timestamp); post.timestampISO = utils.toISOString(post.timestamp);
});
posts = posts.filter(function(post) {
return results.topics[post.tid];
});
parsePosts(posts, options, next);
},
function(posts, next) {
plugins.fireHook('filter:post.getPostSummaryByPids', {posts: posts, uid: uid}, next);
},
function(data, next) {
next(null, data.posts);
}
], callback);
};
function parsePosts(posts, options, callback) {
async.map(posts, function(post, next) {
if (!post.content || !options.parse) { if (!post.content || !options.parse) {
if (options.stripTags) { if (options.stripTags) {
post.content = stripTags(post.content); post.content = stripTags(post.content);
@ -100,19 +113,9 @@ module.exports = function(Posts) {
next(null, post); next(null, post);
}); });
}, function(err, posts) { }, callback);
if (err) {
return callback(err);
} }
plugins.fireHook('filter:post.getPostSummaryByPids', {posts: posts, uid: uid}, function(err, postData) {
callback(err, postData.posts);
});
});
});
});
};
function getTopicAndCategories(topicKeys, callback) { function getTopicAndCategories(topicKeys, callback) {
db.getObjectsFields(topicKeys, ['uid', 'tid', 'title', 'cid', 'slug', 'deleted', 'postcount'], function(err, topics) { db.getObjectsFields(topicKeys, ['uid', 'tid', 'title', 'cid', 'slug', 'deleted', 'postcount'], function(err, topics) {
if (err) { if (err) {

Loading…
Cancel
Save