closes #1419
parent
fa221437dc
commit
68fd997efd
@ -1,83 +1,31 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var async = require('async'),
|
var async = require('async'),
|
||||||
|
|
||||||
db = require('./../database'),
|
db = require('./../database'),
|
||||||
posts = require('./../posts'),
|
posts = require('./../posts'),
|
||||||
topics = require('./../topics');
|
topics = require('./../topics');
|
||||||
|
|
||||||
module.exports = function(Categories) {
|
module.exports = function(Categories) {
|
||||||
|
|
||||||
Categories.isUserActiveIn = function(cid, uid, callback) {
|
Categories.getActiveUsers = function(cid, callback) {
|
||||||
|
db.getSortedSetRevRange('categories:recent_posts:cid:' + cid, 0, 99, function(err, pids) {
|
||||||
db.getSortedSetRange('uid:' + uid + ':posts', 0, -1, function(err, pids) {
|
var keys = pids.map(function(pid) {
|
||||||
if (err) {
|
return 'post:' + pid;
|
||||||
return callback(err);
|
});
|
||||||
}
|
|
||||||
|
|
||||||
var index = 0,
|
|
||||||
active = false;
|
|
||||||
|
|
||||||
async.whilst(
|
db.getObjectsFields(keys, ['uid'], function(err, users) {
|
||||||
function() {
|
|
||||||
return active === false && index < pids.length;
|
|
||||||
},
|
|
||||||
function(callback) {
|
|
||||||
posts.getCidByPid(pids[index], function(err, postCid) {
|
|
||||||
if (err) {
|
if (err) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (postCid === cid) {
|
var uids = users.map(function(user) {
|
||||||
active = true;
|
return user.uid;
|
||||||
}
|
}).filter(function(value, index, array) {
|
||||||
|
return parseInt(value, 10) !== 0 && array.indexOf(value) === index;
|
||||||
++index;
|
}).slice(0, 24);
|
||||||
callback();
|
|
||||||
});
|
|
||||||
},
|
|
||||||
function(err) {
|
|
||||||
callback(err, active);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
Categories.addActiveUser = function(cid, uid, timestamp) {
|
|
||||||
if(parseInt(uid, 10)) {
|
|
||||||
db.sortedSetAdd('cid:' + cid + ':active_users', timestamp, uid);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
Categories.removeActiveUser = function(cid, uid, callback) {
|
|
||||||
db.sortedSetRemove('cid:' + cid + ':active_users', uid, callback);
|
|
||||||
};
|
|
||||||
|
|
||||||
Categories.getActiveUsers = function(cid, callback) {
|
|
||||||
db.getSortedSetRevRange('cid:' + cid + ':active_users', 0, 23, callback);
|
|
||||||
};
|
|
||||||
|
|
||||||
Categories.moveActiveUsers = function(tid, oldCid, cid) {
|
|
||||||
function updateUser(uid, timestamp) {
|
|
||||||
Categories.addActiveUser(cid, uid, timestamp);
|
|
||||||
Categories.isUserActiveIn(oldCid, uid, function(err, active) {
|
|
||||||
|
|
||||||
if (!err && !active) {
|
callback(null, uids);
|
||||||
Categories.removeActiveUser(oldCid, uid);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
topics.getTopicField(tid, 'timestamp', function(err, timestamp) {
|
|
||||||
if(!err) {
|
|
||||||
topics.getUids(tid, function(err, uids) {
|
|
||||||
if (!err && uids) {
|
|
||||||
for (var i = 0; i < uids.length; ++i) {
|
|
||||||
updateUser(uids[i], timestamp);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue