updating topics.getTeaser and get_last_undeleted_pid to return err first, and handled methods that called it

v1.18.x
Julian Lam 12 years ago
parent 5819b43595
commit 31f8be8a0a

@ -132,8 +132,8 @@ var RDB = require('./redis.js'),
} }
function getTeaserInfo(next) { function getTeaserInfo(next) {
topics.getTeaser(topicData.tid, function(teaser) { topics.getTeaser(topicData.tid, function(err, teaser) {
next(null, teaser); next(null, teaser || {});
}); });
} }
@ -178,10 +178,10 @@ var RDB = require('./redis.js'),
topicData.username = topicInfo.username; topicData.username = topicInfo.username;
topicData.badgeclass = (topicInfo.hasread && current_user != 0) ? '' : 'badge-important'; topicData.badgeclass = (topicInfo.hasread && current_user != 0) ? '' : 'badge-important';
topicData.teaser_text = topicInfo.teaserInfo.text, topicData.teaser_text = topicInfo.teaserInfo.text || '',
topicData.teaser_username = topicInfo.teaserInfo.username; topicData.teaser_username = topicInfo.teaserInfo.username || '';
topicData.teaser_userpicture = topicInfo.teaserInfo.picture; topicData.teaser_userpicture = topicInfo.teaserInfo.picture || '';
topicData.teaser_timestamp = utils.relativeTime(topicInfo.teaserInfo.timestamp); topicData.teaser_timestamp = topicInfo.teaserInfo.timestamp ? utils.relativeTime(topicInfo.teaserInfo.timestamp) : '';
if (isTopicVisible(topicData, topicInfo)) if (isTopicVisible(topicData, topicInfo))
retrieved_topics.push(topicData); retrieved_topics.push(topicData);

@ -243,10 +243,12 @@ var RDB = require('./redis.js'),
function(next) { function(next) {
topics.getTopicField(tid, 'title', function(title) { topics.getTopicField(tid, 'title', function(title) {
topics.getTeaser(tid, function(teaser) { topics.getTeaser(tid, function(err, teaser) {
if (!err) {
notifications.create(teaser.username + ' has posted a reply to: "' + title + '"', null, '/topic/' + tid, 'topic:' + tid, function(nid) { notifications.create(teaser.username + ' has posted a reply to: "' + title + '"', null, '/topic/' + tid, 'topic:' + tid, function(nid) {
next(null, nid); next(null, nid);
}); });
} else next(err);
}); });
}); });
@ -259,9 +261,8 @@ var RDB = require('./redis.js'),
}); });
} }
], function(err, results) { ], function(err, results) {
if (!err) { if (!err) notifications.push(results[0], results[1]);
notifications.push(results[0], results[1]); // Otherwise, do nothing
}
}); });
} }

@ -153,7 +153,8 @@ marked.setOptions({
} }
function getTeaser(next) { function getTeaser(next) {
Topics.getTeaser(tid, function(teaser) { Topics.getTeaser(tid, function(err, teaser) {
if (err) teaser = {};
next(null, teaser); next(null, teaser);
}); });
} }
@ -169,9 +170,9 @@ marked.setOptions({
topicData.relativeTime = utils.relativeTime(topicData.timestamp); topicData.relativeTime = utils.relativeTime(topicData.timestamp);
topicData.badgeclass = hasRead ? '' : 'badge-important'; topicData.badgeclass = hasRead ? '' : 'badge-important';
topicData.teaser_text = teaser.text; topicData.teaser_text = teaser.text || '';
topicData.teaser_username = teaser.username; topicData.teaser_username = teaser.username || '';
topicData.teaser_timestamp = utils.relativeTime(teaser.timestamp); topicData.teaser_timestamp = teaser.timestamp ? utils.relativeTime(teaser.timestamp) : '';
callback(topicData); callback(topicData);
}); });
@ -262,23 +263,18 @@ marked.setOptions({
} }
Topics.getTeasers = function(tids, callback) { Topics.getTeasers = function(tids, callback) {
var requests = []; var teasers = [];
if (Array.isArray(tids)) { if (Array.isArray(tids)) {
for(x=0,numTids=tids.length;x<numTids;x++) { async.each(tids, function(tid, next) {
(function(tid) { Topics.getTeaser(tid, function(err, teaser_info) {
requests.push(function(next) { if (err) teaser_info = {};
Topics.getTeaser(tid, function(teaser_info) { teasers.push(teaser_info);
next(null, teaser_info); next();
}); });
}); }, function() {
})(tids[x]);
}
async.parallel(requests, function(err, teasers) {
callback(teasers); callback(teasers);
}); });
} else { } else callback(teasers);
callback([]);
}
} }
@ -288,26 +284,23 @@ marked.setOptions({
var numPosts = posts.length; var numPosts = posts.length;
if(!numPosts) if(!numPosts)
callback(null); return callback(new Error('no-undeleted-pids-found'));
while(numPosts--) { while(numPosts--) {
if(posts[numPosts].deleted !== '1') { if(posts[numPosts].deleted !== '1') {
callback(posts[numPosts].pid); callback(null, posts[numPosts].pid);
return; return;
} }
} }
if(posts.length > 0)
callback(posts[0].pid); // If we got here, nothing was found...
else callback(new Error('no-undeleted-pids-found'));
callback(null);
}); });
} }
Topics.getTeaser = function(tid, callback) { Topics.getTeaser = function(tid, callback) {
Topics.get_latest_undeleted_pid(tid, function(pid) { Topics.get_latest_undeleted_pid(tid, function(err, pid) {
console.log(pid); if (!err) {
if (pid !== null) {
posts.getPostFields(pid, ['content', 'uid', 'timestamp'], function(postData) { posts.getPostFields(pid, ['content', 'uid', 'timestamp'], function(postData) {
user.getUserFields(postData.uid, ['username', 'picture'], function(userData) { user.getUserFields(postData.uid, ['username', 'picture'], function(userData) {
@ -317,7 +310,7 @@ marked.setOptions({
if(postData.content) if(postData.content)
stripped = utils.strip_tags(marked(postData.content)); stripped = utils.strip_tags(marked(postData.content));
callback({ callback(null, {
"text": stripped, "text": stripped,
"username": userData.username, "username": userData.username,
"picture": userData.picture, "picture": userData.picture,
@ -325,14 +318,7 @@ marked.setOptions({
}); });
}); });
}); });
} else { } else callback(new Error('no-teaser-found'));
callback({
"text": "",
"username": "",
"picture": "",
"timestamp" : ""
});
}
}); });
} }

Loading…
Cancel
Save