simpler method for getting pids

v1.18.x
psychobunny 8 years ago
parent 86a8b8ab93
commit 5d9b6062d6

@ -480,43 +480,33 @@ Upgrade.upgrade = function (callback) {
} }
}, },
function (next) { function (next) {
thisSchemaDate = Date.UTC(2017, 1, 27); thisSchemaDate = Date.UTC(2017, 1, 28);
var schemaName = '[2017/2/27] New sorted set posts:votes'; var schemaName = '[2017/2/27] New sorted set posts:votes';
if (schemaDate < thisSchemaDate) { if (schemaDate < thisSchemaDate) {
updatesMade = true; updatesMade = true;
winston.verbose(schemaName); winston.verbose(schemaName);
db.getSortedSetRange('categories:cid', 0, -1, function (err, cids) { require('./batch').processSortedSet('posts:pid', function (pids, next) {
async.each(pids, function (pid, next) {
async.each(pids, function (pid, next) {
db.getObjectFields('post:' + pid, ['upvotes', 'downvotes'], function (err, postData) {
if (err || !postData) {
return next(err);
}
var votes = parseInt(postData.upvotes || 0, 10) - parseInt(postData.downvotes || 0, 10);
db.sortedSetAdd('posts:votes', votes, pid, next);
});
}, next);
}, next);
}, {}, function (err) {
if (err) { if (err) {
return next(err); return next(err);
} }
async.eachSeries(cids, function (cid, next) { winston.info(schemaName + ' - done');
db.getSortedSetRevRange('cid:' + cid + ':pids', 0, -1, function (err, pids) { Upgrade.update(thisSchemaDate, next);
if (err || !pids) {
return next(err);
}
async.each(pids, function(pid, next) {
db.getObjectFields('post:' + pid, ['upvotes', 'downvotes'], function (err, postData) {
if (err || !postData) {
return next(err);
}
var votes = parseInt(postData.upvotes || 0, 10) - parseInt(postData.downvotes || 0, 10);
db.sortedSetAdd('posts:votes', votes, pid, next);
});
}, next);
});
}, function (err) {
if (err) {
return next(err);
}
winston.info(schemaName + ' - done');
Upgrade.update(thisSchemaDate, next);
});
}); });
} else { } else {
winston.info(schemaName + ' - skipped!'); winston.info(schemaName + ' - skipped!');

Loading…
Cancel
Save