Changing behavior of the same user on a pad. Kick old sessions instead of refusing new

This commit is contained in:
Peter 'Pita' Martischka 2011-06-04 18:02:22 +01:00
parent bf32c18d8d
commit b692ffec0b
2 changed files with 18 additions and 30 deletions

View File

@ -520,15 +520,14 @@ function handleClientReady(client, message)
}, },
function(callback) function(callback)
{ {
//Check if this author is already on the pad, if yes, kick him! //Check if this author is already on the pad, if yes, kick the other sessions!
if(pad2sessions[message.padId]) if(pad2sessions[message.padId])
{ {
for(var i in pad2sessions[message.padId]) for(var i in pad2sessions[message.padId])
{ {
if(sessioninfos[pad2sessions[message.padId][i]].author == author) if(sessioninfos[pad2sessions[message.padId][i]].author == author)
{ {
client.send({disconnect:"doublelogin"}); socketio.clients[pad2sessions[message.padId][i]].send({disconnect:"doublelogin"});
return;
} }
} }
} }

View File

@ -89,16 +89,6 @@ function handshake()
socket.on('message', function(obj){ socket.on('message', function(obj){
//if we haven't recieved the clientVars yet, then this message should it be //if we haven't recieved the clientVars yet, then this message should it be
if(!receivedClientVars) if(!receivedClientVars)
{
//We get a disconnect message
if(obj.disconnect)
{
socket.disconnect();
padconnectionstatus.disconnected("userdup");
return;
}
//yeah, the clientVars are here :). So we can start initalizing the Pad
else
{ {
if(window.console) if(window.console)
console.log(obj); console.log(obj);
@ -113,16 +103,15 @@ function handshake()
initalized=true; initalized=true;
} }
}
//This handles every Message after the clientVars //This handles every Message after the clientVars
else else
{ {
//We can't handle the message before we initalized the pad, so let this message bounce back in 100ms if(obj.disconnect)
if(!initalized)
{ {
setTimeOut(this(obj), 100); socket.disconnect();
padconnectionstatus.disconnected("userdup");
return;
} }
//We're initalized, so give this message to the collabClient
else else
{ {
pad.collabClient.handleMessageFromServer(obj); pad.collabClient.handleMessageFromServer(obj);