mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-30 18:46:01 +01:00
update online users regardless of status
This commit is contained in:
@@ -42,8 +42,9 @@ middleware.applyCSRF = csrf();
|
|||||||
middleware.ensureLoggedIn = ensureLoggedIn.ensureLoggedIn();
|
middleware.ensureLoggedIn = ensureLoggedIn.ensureLoggedIn();
|
||||||
|
|
||||||
middleware.updateLastOnlineTime = function(req, res, next) {
|
middleware.updateLastOnlineTime = function(req, res, next) {
|
||||||
if(req.user) {
|
if (req.user) {
|
||||||
user.updateLastOnlineTime(req.user.uid);
|
user.updateLastOnlineTime(req.user.uid);
|
||||||
|
user.updateOnlineUsers(req.user.uid);
|
||||||
}
|
}
|
||||||
|
|
||||||
db.sortedSetScore('ip:recent', req.ip, function(err, score) {
|
db.sortedSetScore('ip:recent', req.ip, function(err, score) {
|
||||||
|
|||||||
15
src/user.js
15
src/user.js
@@ -138,16 +138,25 @@ var async = require('async'),
|
|||||||
callback = callback || function() {};
|
callback = callback || function() {};
|
||||||
User.getUserFields(uid, ['status', 'lastonline'], function(err, userData) {
|
User.getUserFields(uid, ['status', 'lastonline'], function(err, userData) {
|
||||||
var now = Date.now();
|
var now = Date.now();
|
||||||
if(err || userData.status === 'offline' || now - parseInt(userData.lastonline, 10) < 300000) {
|
if (err || userData.status === 'offline' || now - parseInt(userData.lastonline, 10) < 300000) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
db.sortedSetAdd('users:online', now, uid);
|
|
||||||
|
|
||||||
User.setUserField(uid, 'lastonline', now, callback);
|
User.setUserField(uid, 'lastonline', now, callback);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
User.updateOnlineUsers = function(uid, callback) {
|
||||||
|
callback = callback || function() {};
|
||||||
|
db.sortedSetScore('users:online', uid, function(err, score) {
|
||||||
|
var now = Date.now();
|
||||||
|
if (err || now - parseInt(score, 10) < 300000) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
db.sortedSetAdd('users:online', now, uid, callback);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
User.setUserField = function(uid, field, value, callback) {
|
User.setUserField = function(uid, field, value, callback) {
|
||||||
plugins.fireHook('action:user.set', {field: field, value: value, type: 'set'});
|
plugins.fireHook('action:user.set', {field: field, value: value, type: 'set'});
|
||||||
db.setObjectField('user:' + uid, field, value, callback);
|
db.setObjectField('user:' + uid, field, value, callback);
|
||||||
|
|||||||
Reference in New Issue
Block a user