fixed session ids

v1.18.x
Baris Usakli 12 years ago
parent bef0bd87da
commit 44485a2e40

@ -1,13 +1,11 @@
var SocketIO = require('socket.io').listen(global.server), var SocketIO = require('socket.io').listen(global.server,{log:false}),
cookie = require('cookie'), cookie = require('cookie'),
connect = require('connect'), connect = require('connect'),
config = require('../config.js'); config = require('../config.js');
(function(io) { (function(io) {
var modules = null, var modules = null,
sessionID, users = {};
uid;
global.io = io; global.io = io;
module.exports.init = function() { module.exports.init = function() {
modules = global.modules; modules = global.modules;
@ -28,10 +26,15 @@ var SocketIO = require('socket.io').listen(global.server),
} }
// Otherwise, continue unimpeded. // Otherwise, continue unimpeded.
sessionID = handshakeData.sessionID; var sessionID = handshakeData.sessionID;
global.modules.user.get_uid_by_session(sessionID, function(session_uid) {
if (session_uid) uid = session_uid; global.modules.user.get_uid_by_session(sessionID, function(userId) {
else uid = 0; if (userId)
{
users[sessionID] = userId;
}
else
users[sessionID] = 0;
accept(null, true); accept(null, true);
}); });
@ -39,6 +42,10 @@ var SocketIO = require('socket.io').listen(global.server),
io.sockets.on('connection', function(socket) { io.sockets.on('connection', function(socket) {
var hs = socket.handshake;
var uid = users[hs.sessionID];
if (DEVELOPMENT === true) { if (DEVELOPMENT === true) {
// refreshing templates // refreshing templates
modules.templates.init(); modules.templates.init();
@ -50,9 +57,16 @@ var SocketIO = require('socket.io').listen(global.server),
socket.emit('event:consolelog',{type:'uncaughtException', stack:err.stack, error:err.toString()}); socket.emit('event:consolelog',{type:'uncaughtException', stack:err.stack, error:err.toString()});
}); });
socket.emit('event:connect', {status: 1}); socket.emit('event:connect', {status: 1});
socket.on('disconnect', function() {
console.log('Got disconnect! SESSION ID : '+hs.sessionID+' USER ID : '+uid);
delete users[hs.sessionID];
console.log(users);
});
// BEGIN: API calls (todo: organize) // BEGIN: API calls (todo: organize)
// julian: :^) // julian: :^)
socket.on('api:user.get', function(data) { socket.on('api:user.get', function(data) {

Loading…
Cancel
Save