mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-30 02:25:55 +01:00
feat: closes #10324, show recently online users as well
This commit is contained in:
@@ -148,14 +148,22 @@ usersController.getUsers = async function (set, uid, query) {
|
|||||||
usersController.getUsersAndCount = async function (set, uid, start, stop) {
|
usersController.getUsersAndCount = async function (set, uid, start, stop) {
|
||||||
async function getCount() {
|
async function getCount() {
|
||||||
if (set === 'users:online') {
|
if (set === 'users:online') {
|
||||||
return await db.sortedSetCount('users:online', Date.now() - (meta.config.onlineCutoff * 60000), '+inf');
|
return await db.sortedSetCount('users:online', Date.now() - 86400000, '+inf');
|
||||||
} else if (set === 'users:banned' || set === 'users:flags') {
|
} else if (set === 'users:banned' || set === 'users:flags') {
|
||||||
return await db.sortedSetCard(set);
|
return await db.sortedSetCard(set);
|
||||||
}
|
}
|
||||||
return await db.getObjectField('global', 'userCount');
|
return await db.getObjectField('global', 'userCount');
|
||||||
}
|
}
|
||||||
|
async function getUsers() {
|
||||||
|
if (set === 'users:online') {
|
||||||
|
const count = parseInt(stop, 10) === -1 ? stop : stop - start + 1;
|
||||||
|
const uids = await db.getSortedSetRevRangeByScore(set, start, count, '+inf', Date.now() - 86400000);
|
||||||
|
return await user.getUsers(uids, uid);
|
||||||
|
}
|
||||||
|
return await user.getUsersFromSet(set, uid, start, stop);
|
||||||
|
}
|
||||||
const [usersData, count] = await Promise.all([
|
const [usersData, count] = await Promise.all([
|
||||||
user.getUsersFromSet(set, uid, start, stop),
|
getUsers(),
|
||||||
getCount(),
|
getCount(),
|
||||||
]);
|
]);
|
||||||
return {
|
return {
|
||||||
|
|||||||
Reference in New Issue
Block a user