closes #6214
parent
b58387c822
commit
9d7e0775aa
@ -0,0 +1,53 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var async = require('async');
|
||||||
|
var batch = require('../../batch');
|
||||||
|
var db = require('../../database');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'Fix sort by votes for moved topics',
|
||||||
|
timestamp: Date.UTC(2018, 0, 8),
|
||||||
|
method: function (callback) {
|
||||||
|
var progress = this.progress;
|
||||||
|
|
||||||
|
batch.processSortedSet('topics:tid', function (tids, next) {
|
||||||
|
async.eachLimit(tids, 500, function (tid, _next) {
|
||||||
|
progress.incr();
|
||||||
|
var topicData;
|
||||||
|
async.waterfall([
|
||||||
|
function (next) {
|
||||||
|
db.getObjectFields('topic:' + tid, ['cid', 'oldCid', 'upvotes', 'downvotes', 'pinned'], next);
|
||||||
|
},
|
||||||
|
function (_topicData, next) {
|
||||||
|
topicData = _topicData;
|
||||||
|
if (!topicData.cid || !topicData.oldCid) {
|
||||||
|
return _next();
|
||||||
|
}
|
||||||
|
|
||||||
|
var upvotes = parseInt(topicData.upvotes, 10) || 0;
|
||||||
|
var downvotes = parseInt(topicData.downvotes, 10) || 0;
|
||||||
|
var votes = upvotes - downvotes;
|
||||||
|
|
||||||
|
async.parallel([
|
||||||
|
function (next) {
|
||||||
|
db.sortedSetRemove('cid:' + topicData.oldCid + ':tids:votes', tid, next);
|
||||||
|
},
|
||||||
|
function (next) {
|
||||||
|
if (!parseInt(topicData.pinned, 10)) {
|
||||||
|
db.sortedSetAdd('cid:' + topicData.cid + ':tids:votes', votes, tid, next);
|
||||||
|
} else {
|
||||||
|
next();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
], function (err) {
|
||||||
|
next(err);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
], _next);
|
||||||
|
}, next);
|
||||||
|
}, {
|
||||||
|
progress: progress,
|
||||||
|
batch: 500,
|
||||||
|
}, callback);
|
||||||
|
},
|
||||||
|
};
|
Loading…
Reference in New Issue