mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-02 03:55:55 +01:00
changes to online users code
This commit is contained in:
@@ -399,10 +399,12 @@ body .navbar .nodebb-inline-block {
|
|||||||
.icon-circle {
|
.icon-circle {
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
color: green;
|
color: green;
|
||||||
|
margin-right:3px;
|
||||||
}
|
}
|
||||||
.icon-circle-blank {
|
.icon-circle-blank {
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
color: red;
|
color: red;
|
||||||
|
margin-right:3px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -86,9 +86,11 @@ var socket,
|
|||||||
uid = el.parents('li').attr('data-uid');
|
uid = el.parents('li').attr('data-uid');
|
||||||
|
|
||||||
if (uid && jQuery.inArray(uid, users) !== -1) {
|
if (uid && jQuery.inArray(uid, users) !== -1) {
|
||||||
el.prepend('<i class="icon-circle"></i> ');
|
el.find('i').remove();
|
||||||
|
el.prepend('<i class="icon-circle"></i>');
|
||||||
} else {
|
} else {
|
||||||
el.prepend('<i class="icon-circle-blank"></i> ');
|
el.find('i').remove();
|
||||||
|
el.prepend('<i class="icon-circle-blank"></i>');
|
||||||
}
|
}
|
||||||
|
|
||||||
el.processed = true;
|
el.processed = true;
|
||||||
@@ -208,25 +210,25 @@ var socket,
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
app.populate_online_users = function() {
|
||||||
|
var uids = [];
|
||||||
|
|
||||||
|
jQuery('.post-row').each(function() {
|
||||||
|
uids.push(this.getAttribute('data-uid'));
|
||||||
|
});
|
||||||
|
|
||||||
|
socket.emit('api:user.get_online_users', uids);
|
||||||
|
}
|
||||||
|
|
||||||
app.process_page = function() {
|
app.process_page = function() {
|
||||||
|
|
||||||
function populate_online_users() {
|
|
||||||
var uids = [];
|
|
||||||
|
|
||||||
jQuery('.post-row').each(function() {
|
|
||||||
uids.push(this.getAttribute('data-uid'));
|
|
||||||
});
|
|
||||||
|
|
||||||
socket.emit('api:user.get_online_users', uids);
|
|
||||||
}
|
|
||||||
|
|
||||||
// here is where all modules' onNavigate should be called, I think.
|
// here is where all modules' onNavigate should be called, I think.
|
||||||
require(['mobileMenu'], function(mobileMenu) {
|
require(['mobileMenu'], function(mobileMenu) {
|
||||||
mobileMenu.onNavigate();
|
mobileMenu.onNavigate();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
populate_online_users();
|
app.populate_online_users();
|
||||||
|
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
window.scrollTo(0, 1); // rehide address bar on mobile after page load completes.
|
window.scrollTo(0, 1); // rehide address bar on mobile after page load completes.
|
||||||
|
|||||||
@@ -324,6 +324,8 @@
|
|||||||
var activeEl = $('#thread_active_users');
|
var activeEl = $('#thread_active_users');
|
||||||
if(activeEl.length)
|
if(activeEl.length)
|
||||||
activeEl.html(data);
|
activeEl.html(data);
|
||||||
|
|
||||||
|
app.populate_online_users();
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on('event:rep_up', function(data) {
|
socket.on('event:rep_up', function(data) {
|
||||||
@@ -351,6 +353,7 @@
|
|||||||
tempContainer.replaceWith(tempContainer.contents());
|
tempContainer.replaceWith(tempContainer.contents());
|
||||||
infiniteLoaderActive = false;
|
infiniteLoaderActive = false;
|
||||||
|
|
||||||
|
app.populate_online_users();
|
||||||
addCommasToNumbers();
|
addCommasToNumbers();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
23
src/user.js
23
src/user.js
@@ -904,29 +904,6 @@ var utils = require('./../public/src/utils.js'),
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
User.get_online_users = function(socket, uids) {
|
|
||||||
RDB.sismembers('users:online', uids, function(err, data) {
|
|
||||||
RDB.handle(err);
|
|
||||||
socket.emit('api:user.get_online_users', data);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
User.go_online = function(uid) {
|
|
||||||
RDB.sadd('users:online', uid, function(err) {
|
|
||||||
if (err) {
|
|
||||||
RDB.handle(err);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
User.go_offline = function(uid) {
|
|
||||||
RDB.srem('users:online', uid, function(err) {
|
|
||||||
if (err) {
|
|
||||||
RDB.handle(err);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
User.active = {
|
User.active = {
|
||||||
get_record : function(socket) {
|
get_record : function(socket) {
|
||||||
RDB.mget(['global:active_user_record', 'global:active_user_record_date'], function(err, data) {
|
RDB.mget(['global:active_user_record', 'global:active_user_record_date'], function(err, data) {
|
||||||
|
|||||||
@@ -58,43 +58,35 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
var hs = socket.handshake;
|
var hs = socket.handshake;
|
||||||
|
|
||||||
var uid = users[hs.sessionID];
|
var uid = users[hs.sessionID];
|
||||||
// if (uid > 0) {
|
|
||||||
userSockets[uid] = userSockets[uid] || [];
|
|
||||||
userSockets[uid].push(socket);
|
|
||||||
user.go_online(uid);
|
|
||||||
|
|
||||||
socket.join('uid_' + uid);
|
|
||||||
// }
|
|
||||||
|
|
||||||
/*process.on('uncaughtException', function(err) {
|
userSockets[uid] = userSockets[uid] || [];
|
||||||
// handle the error safely
|
userSockets[uid].push(socket);
|
||||||
console.log("error message "+err);
|
|
||||||
socket.emit('event:consolelog',{type:'uncaughtException', stack:err.stack, error:err.toString()});
|
|
||||||
});*/
|
|
||||||
|
|
||||||
|
|
||||||
|
socket.join('uid_' + uid);
|
||||||
|
|
||||||
socket.emit('event:connect', {status: 1});
|
socket.emit('event:connect', {status: 1});
|
||||||
|
|
||||||
socket.on('disconnect', function() {
|
socket.on('disconnect', function() {
|
||||||
// if (uid > 0) {
|
|
||||||
user.go_offline(uid);
|
var index = userSockets[uid].indexOf(socket);
|
||||||
|
if(index !== -1) {
|
||||||
|
userSockets[uid].splice(index, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(userSockets[uid].length === 0)
|
||||||
delete users[hs.sessionID];
|
delete users[hs.sessionID];
|
||||||
var index = userSockets[uid].indexOf(socket);
|
|
||||||
if(index !== -1) {
|
for(var roomName in rooms) {
|
||||||
userSockets[uid].splice(index, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
for(var roomName in rooms) {
|
|
||||||
|
|
||||||
socket.leave(roomName);
|
socket.leave(roomName);
|
||||||
|
|
||||||
if(rooms[roomName][hs.sessionID]) {
|
if(rooms[roomName][socket.id]) {
|
||||||
delete rooms[roomName][hs.sessionID];
|
delete rooms[roomName][socket.id];
|
||||||
}
|
}
|
||||||
|
|
||||||
updateRoomBrowsingText(roomName);
|
|
||||||
}
|
|
||||||
|
|
||||||
// }
|
updateRoomBrowsingText(roomName);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on('api:get_all_rooms', function(data) {
|
socket.on('api:get_all_rooms', function(data) {
|
||||||
@@ -105,9 +97,9 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
|
|
||||||
function getUidsInRoom(room) {
|
function getUidsInRoom(room) {
|
||||||
var uids = [];
|
var uids = [];
|
||||||
for(var sessionId in room) {
|
for(var socketId in room) {
|
||||||
if(uids.indexOf(room[sessionId]) === -1)
|
if(uids.indexOf(room[socketId]) === -1)
|
||||||
uids.push(room[sessionId]);
|
uids.push(room[socketId]);
|
||||||
}
|
}
|
||||||
return uids;
|
return uids;
|
||||||
}
|
}
|
||||||
@@ -118,6 +110,7 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
|
|
||||||
for(var i=0; i<clients.length; ++i) {
|
for(var i=0; i<clients.length; ++i) {
|
||||||
var hs = clients[i].handshake;
|
var hs = clients[i].handshake;
|
||||||
|
|
||||||
if(hs && !users[hs.sessionID]) {
|
if(hs && !users[hs.sessionID]) {
|
||||||
++anonCount;
|
++anonCount;
|
||||||
}
|
}
|
||||||
@@ -163,17 +156,17 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
|
|
||||||
rooms[data.enter] = rooms[data.enter] || {};
|
rooms[data.enter] = rooms[data.enter] || {};
|
||||||
|
|
||||||
if(data.leave) {
|
if (uid) {
|
||||||
if (uid) {
|
rooms[data.enter][socket.id] = uid;
|
||||||
rooms[data.enter][hs.sessionID] = uid;
|
|
||||||
|
|
||||||
if (data.leave && rooms[data.leave] && rooms[data.leave][hs.sessionID]) {
|
if (data.leave && rooms[data.leave] && rooms[data.leave][socket.id]) {
|
||||||
delete rooms[data.leave][hs.sessionID];
|
delete rooms[data.leave][socket.id];
|
||||||
}
|
|
||||||
}
|
}
|
||||||
updateRoomBrowsingText(data.leave);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(data.leave)
|
||||||
|
updateRoomBrowsingText(data.leave);
|
||||||
|
|
||||||
updateRoomBrowsingText(data.enter);
|
updateRoomBrowsingText(data.enter);
|
||||||
|
|
||||||
if (data.enter != 'admin')
|
if (data.enter != 'admin')
|
||||||
@@ -185,7 +178,6 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
|
|
||||||
socket.on('api:updateHeader', function(data) {
|
socket.on('api:updateHeader', function(data) {
|
||||||
if(uid) {
|
if(uid) {
|
||||||
|
|
||||||
user.getUserFields(uid, data.fields, function(fields) {
|
user.getUserFields(uid, data.fields, function(fields) {
|
||||||
fields.uid = uid;
|
fields.uid = uid;
|
||||||
socket.emit('api:updateHeader', fields);
|
socket.emit('api:updateHeader', fields);
|
||||||
@@ -237,7 +229,16 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
});
|
});
|
||||||
|
|
||||||
socket.on('api:user.get_online_users', function(data) {
|
socket.on('api:user.get_online_users', function(data) {
|
||||||
user.get_online_users(socket, data);
|
var returnData = [];
|
||||||
|
|
||||||
|
for(var i=0; i<data.length; ++i) {
|
||||||
|
var uid = data[i];
|
||||||
|
if(userSockets[uid] && userSockets[uid].length > 0)
|
||||||
|
returnData.push(uid);
|
||||||
|
else
|
||||||
|
returnData.push(0);
|
||||||
|
}
|
||||||
|
socket.emit('api:user.get_online_users', returnData);
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on('api:user.changePassword', function(data) {
|
socket.on('api:user.changePassword', function(data) {
|
||||||
|
|||||||
Reference in New Issue
Block a user