|
|
|
"use strict";
|
|
|
|
|
|
|
|
var usersController = {};
|
|
|
|
|
|
|
|
var async = require('async'),
|
|
|
|
user = require('../user'),
|
|
|
|
meta = require('../meta'),
|
|
|
|
db = require('../database');
|
|
|
|
|
|
|
|
usersController.getOnlineUsers = function(req, res, next) {
|
|
|
|
var websockets = require('../socket.io');
|
|
|
|
var uid = req.user ? req.user.uid : 0;
|
|
|
|
|
|
|
|
async.parallel({
|
|
|
|
users: function(next) {
|
|
|
|
user.getUsersFromSet('users:online', 0, 49, next);
|
|
|
|
},
|
|
|
|
count: function(next) {
|
|
|
|
var now = Date.now();
|
|
|
|
db.sortedSetCount('users:online', now - 300000, now, next);
|
|
|
|
},
|
|
|
|
isAdministrator: function(next) {
|
|
|
|
user.isAdministrator(uid, next);
|
|
|
|
}
|
|
|
|
}, function(err, results) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!results.isAdministrator) {
|
|
|
|
results.users = results.users.filter(function(user) {
|
|
|
|
return user && user.status !== 'offline';
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
var anonymousUserCount = websockets.getOnlineAnonCount();
|
|
|
|
|
|
|
|
var userData = {
|
|
|
|
search_display: 'hidden',
|
|
|
|
loadmore_display: results.count > 50 ? 'block' : 'hide',
|
|
|
|
users: results.users,
|
|
|
|
anonymousUserCount: anonymousUserCount,
|
|
|
|
show_anon: anonymousUserCount ? '' : 'hide'
|
|
|
|
};
|
|
|
|
|
|
|
|
res.render('users', userData);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
usersController.getUsersSortedByPosts = function(req, res, next) {
|
|
|
|
getUsers('users:postcount', res, next);
|
|
|
|
};
|
|
|
|
|
|
|
|
usersController.getUsersSortedByReputation = function(req, res, next) {
|
|
|
|
getUsers('users:reputation', res, next);
|
|
|
|
};
|
|
|
|
|
|
|
|
usersController.getUsersSortedByJoinDate = function(req, res, next) {
|
|
|
|
getUsers('users:joindate', res, next);
|
|
|
|
};
|
|
|
|
|
|
|
|
function getUsers(set, res, next) {
|
|
|
|
getUsersAndCount(set, 50, function(err, data) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
|
|
|
var userData = {
|
|
|
|
search_display: 'hidden',
|
|
|
|
loadmore_display: data.count > 50 ? 'block' : 'hide',
|
|
|
|
users: data.users,
|
|
|
|
show_anon: 'hide'
|
|
|
|
};
|
|
|
|
|
|
|
|
res.render('users', userData);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getUsersAndCount(set, count, callback) {
|
|
|
|
async.parallel({
|
|
|
|
users: function(next) {
|
|
|
|
user.getUsersFromSet(set, 0, count - 1, next);
|
|
|
|
},
|
|
|
|
count: function(next) {
|
|
|
|
db.getObjectField('global', 'userCount', next);
|
|
|
|
}
|
|
|
|
}, function(err, results) {
|
|
|
|
if (err) {
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
results.users = results.users.filter(function(user) {
|
|
|
|
return user && parseInt(user.uid, 10);
|
|
|
|
});
|
|
|
|
|
|
|
|
callback(null, {users: results.users, count: results.count});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
usersController.getUsersForSearch = function(req, res, next) {
|
|
|
|
var resultsPerPage = parseInt(meta.config.userSearchResultsPerPage, 10) || 20;
|
|
|
|
getUsersAndCount('users:joindate', resultsPerPage, function(err, data) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
var result = {
|
|
|
|
search_display: 'block',
|
|
|
|
loadmore_display: 'hidden',
|
|
|
|
users: data.users,
|
|
|
|
show_anon: 'hide'
|
|
|
|
};
|
|
|
|
|
|
|
|
res.render('users', result);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = usersController;
|