2017-04-16 15:49:53 +00:00
|
|
|
// ABOUT
|
|
|
|
// Runs the Plex Together Server software - handles rooms
|
|
|
|
// Defaults to 8089
|
2017-04-07 05:09:03 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
// USER CONFIG
|
2017-04-07 05:09:03 +00:00
|
|
|
var PORT = 8089
|
2017-04-11 15:51:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-04-07 05:09:03 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
|
|
|
|
// END USER CONFIG
|
2017-04-07 05:09:03 +00:00
|
|
|
var express = require('express');
|
2017-04-10 17:08:43 +00:00
|
|
|
var path = require('path');
|
2017-04-11 15:51:07 +00:00
|
|
|
var cors = require('cors')
|
2017-04-10 17:08:43 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
var root = express()
|
|
|
|
root.use(cors())
|
2017-04-10 17:08:43 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
var combined = express()
|
2017-04-10 17:08:43 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
var ptserver = express();
|
2017-04-10 17:08:43 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
// Setup our PTServer
|
|
|
|
ptserver.get('/',function(req,res){
|
2017-04-16 15:49:53 +00:00
|
|
|
return res.send("You've connected to the PTServer, you're probably looking for the webapp.")
|
2017-04-11 15:51:07 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
// Merge everything together
|
|
|
|
|
2017-04-17 10:16:10 +00:00
|
|
|
root.use('/ptserver',ptserver)
|
2017-04-11 15:51:07 +00:00
|
|
|
root.get('*',function(req,res){
|
2017-04-16 15:49:53 +00:00
|
|
|
return res.send('You\'ve connected to the PTServer, you\'re probably looking for the webapp.')
|
2017-04-10 17:08:43 +00:00
|
|
|
})
|
2017-04-11 15:51:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var rootserver = require('http').createServer(root);
|
2017-04-17 10:16:10 +00:00
|
|
|
var ptserver_io = require('socket.io')(rootserver,{path: '/ptserver/socket.io'});
|
2017-04-10 17:08:43 +00:00
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
|
|
|
|
ptserver_io.on('connection', function(socket){
|
|
|
|
console.log('Someone connected to the ptserver socket')
|
|
|
|
|
2017-04-07 05:09:03 +00:00
|
|
|
socket.on('join',function(data){
|
|
|
|
//A user is attempting to join a room
|
|
|
|
if (data == null){
|
|
|
|
return
|
|
|
|
}
|
|
|
|
var tempUser = new user()
|
|
|
|
var result = true
|
|
|
|
var _data = {}
|
|
|
|
var details = "Successfully connected to " + data.room
|
|
|
|
|
|
|
|
if (socket.selfUser != null || socket.selfUser != undefined){
|
|
|
|
//Already in a room! Leave the room we're in
|
|
|
|
handleDisconnect(false)
|
|
|
|
}
|
2017-04-11 15:51:07 +00:00
|
|
|
var room = ptserver_io.sockets.adapter.rooms[data.room]
|
2017-04-07 05:09:03 +00:00
|
|
|
let isFresh = false
|
|
|
|
if (room === undefined || room.users === undefined || room.users === null){
|
|
|
|
isFresh = true
|
|
|
|
socket.join(data.room)
|
2017-04-11 15:51:07 +00:00
|
|
|
room = ptserver_io.sockets.adapter.rooms[data.room]
|
2017-04-07 05:09:03 +00:00
|
|
|
room.users = []
|
|
|
|
room.password = data.password
|
|
|
|
tempUser.role = 'host'
|
|
|
|
tempUser.username = getValidUsername([],data.username)
|
|
|
|
} else {
|
|
|
|
tempUser.username = getValidUsername(room.users,data.username)
|
|
|
|
if (room.password == null || room.password == ''){
|
|
|
|
//Check if we've already got a Host
|
|
|
|
if (room.hostUsername == null){
|
|
|
|
// We dont have a host user yet.
|
|
|
|
// This should never happen..
|
|
|
|
room.hostUsername = tempUser.username
|
|
|
|
tempUser.role = 'host'
|
|
|
|
socket.join(data.room)
|
|
|
|
} else {
|
|
|
|
tempUser.role = 'guest'
|
|
|
|
socket.join(data.room)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
//This room has a password
|
|
|
|
if (room.password == data.password){
|
|
|
|
//Good password!
|
|
|
|
if (room.hostUsername == null){
|
|
|
|
//We dont have a host user yet.
|
|
|
|
console.log('We dont have a host user')
|
|
|
|
room.hostUsername = tempUser.username
|
|
|
|
tempUser.role = 'host'
|
|
|
|
socket.join(data.room)
|
|
|
|
} else {
|
|
|
|
tempUser.role = 'guest'
|
|
|
|
socket.join(data.room)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
result = false
|
|
|
|
details = 'wrong password'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
tempUser.avatarUrl = data.avatarUrl
|
|
|
|
|
|
|
|
//We've sorted out where the user should go, lets send back
|
|
|
|
var currentUsers = null
|
|
|
|
if (result){
|
|
|
|
tempUser.room = data.room
|
|
|
|
console.log('User ' + tempUser.username + ' joined ' + tempUser.room)
|
|
|
|
if (tempUser.role == 'host'){
|
|
|
|
room.hostUsername = tempUser.username
|
|
|
|
}
|
|
|
|
room.users.push(tempUser)
|
|
|
|
console.log('they joined OK and were given the username ' + tempUser.username)
|
|
|
|
|
|
|
|
socket.broadcast.to(data.room).emit('user-joined',room.users,tempUser)
|
|
|
|
//Set some objects on the socket for ease of use down the road
|
|
|
|
socket.ourRoom = data.room
|
|
|
|
socket.selfUser = tempUser
|
|
|
|
currentUsers = room.users
|
|
|
|
} else {
|
2017-04-10 10:30:05 +00:00
|
|
|
console.log('User failed to join a room')
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
_data = tempUser
|
|
|
|
socket.emit('join-result',result,_data,details,currentUsers)
|
|
|
|
})
|
|
|
|
socket.on('poll', function(data){
|
|
|
|
if (socket.ourRoom == null){
|
2017-04-16 15:49:53 +00:00
|
|
|
//console.log('This user should join a room first')
|
2017-04-07 05:09:03 +00:00
|
|
|
socket.emit('flowerror','You aren\' connected to a room! Use join')
|
|
|
|
socket.emit('rejoin')
|
|
|
|
return
|
|
|
|
}
|
|
|
|
//Recieved an update from a user
|
|
|
|
updateUserData(socket.selfUser.username,data,socket.selfUser.room)
|
|
|
|
//var users = io.sockets.adapter.rooms['hotline123'].users
|
|
|
|
//console.log(JSON.stringify(io.sockets.adapter.rooms, null, 2))
|
|
|
|
/*var clients_in_the_room = io.sockets.adapter.rooms[roomId];
|
|
|
|
for (var clientId in clients_in_the_room ) {
|
|
|
|
//console.log('client: %s', clientId); //Seeing is believing
|
|
|
|
var client_socket = io.sockets.connected[clientId];//Do whatever you want with this
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2017-04-11 15:51:07 +00:00
|
|
|
socket.emit('poll-result',ptserver_io.sockets.adapter.rooms[socket.selfUser.room].users)
|
|
|
|
var room = ptserver_io.sockets.adapter.rooms[socket.selfUser.room]
|
2017-04-07 05:09:03 +00:00
|
|
|
if (socket.selfUser.role == 'host'){
|
|
|
|
//We're the host, broadcast to all clients our data
|
|
|
|
var temp = {}
|
|
|
|
temp.time = data.time
|
|
|
|
temp.maxTime = data.maxTime
|
|
|
|
temp.title = data.title
|
|
|
|
temp.rawTitle = data.rawTitle
|
|
|
|
temp.lastHeartbeat = (new Date).getTime()
|
|
|
|
temp.playerState = data.playerState
|
|
|
|
temp.clientResponseTime = data.clientResponseTime
|
|
|
|
temp.type = data.type
|
|
|
|
temp.showName = data.showName
|
|
|
|
socket.broadcast.to(socket.selfUser.room).emit('host-update',temp)
|
|
|
|
}
|
|
|
|
});
|
|
|
|
socket.on('send_message',function(msg){
|
2017-04-10 10:30:05 +00:00
|
|
|
//console.log(msg)
|
2017-04-07 05:09:03 +00:00
|
|
|
if (socket.ourRoom == null){
|
2017-04-10 10:31:11 +00:00
|
|
|
//console.log('This user should join a room first')
|
2017-04-07 05:09:03 +00:00
|
|
|
socket.emit('flowerror','You aren\' connected to a room! Use join')
|
|
|
|
socket.emit('rejoin')
|
|
|
|
return
|
|
|
|
}
|
2017-04-10 10:30:05 +00:00
|
|
|
//console.log('New message in channel ' + socket.selfUser.room + ' from ' + socket.selfUser.username + ' saying ' + msg)
|
2017-04-07 05:09:03 +00:00
|
|
|
socket.broadcast.to(socket.selfUser.room).emit('new_message',{
|
|
|
|
msg: msg.msg,
|
|
|
|
user: {
|
|
|
|
username: socket.selfUser.username,
|
|
|
|
thumb: socket.selfUser.avatarUrl
|
|
|
|
},
|
|
|
|
type: msg.type
|
|
|
|
})
|
|
|
|
})
|
|
|
|
socket.on('connect_timeout',function(){
|
2017-04-10 10:31:11 +00:00
|
|
|
//console.log('timeout')
|
2017-04-07 05:09:03 +00:00
|
|
|
handleDisconnect(true)
|
|
|
|
})
|
|
|
|
socket.on('disconnect', function(){
|
|
|
|
handleDisconnect(true)
|
|
|
|
});
|
|
|
|
function handleDisconnect(disconnect){
|
|
|
|
if (socket.selfUser === undefined || socket.selfUser === null){
|
|
|
|
return
|
|
|
|
}
|
2017-04-10 10:31:11 +00:00
|
|
|
//console.log('User left: ' + socket.selfUser.username)
|
2017-04-07 05:09:03 +00:00
|
|
|
if (socket.selfUser.role == 'host'){
|
|
|
|
//Our Host has left, lets give the next Guest the Host role
|
|
|
|
var newHost = transferHost(socket.selfUser.room)
|
2017-04-10 10:31:11 +00:00
|
|
|
//console.log('The new host is ' + newHost)
|
|
|
|
//console.log(JSON.stringify(newHost,null,4))
|
2017-04-07 05:09:03 +00:00
|
|
|
socket.broadcast.to(socket.selfUser.room).emit('host-swap',newHost)
|
|
|
|
}
|
|
|
|
removeUser(socket.selfUser.room,socket.selfUser.username)
|
2017-04-11 15:51:07 +00:00
|
|
|
if (ptserver_io.sockets.adapter.rooms[socket.selfUser.room]){
|
|
|
|
socket.broadcast.to(socket.selfUser.room).emit('user-left',ptserver_io.sockets.adapter.rooms[socket.selfUser.room].users,socket.selfUser)
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
socket.disconnect(disconnect)
|
|
|
|
}
|
2017-04-10 17:08:43 +00:00
|
|
|
function updateUserData(username,userData,room){
|
2017-04-11 15:51:07 +00:00
|
|
|
for (var i in ptserver_io.sockets.adapter.rooms[room].users){
|
|
|
|
var user = ptserver_io.sockets.adapter.rooms[room].users[i]
|
2017-04-10 17:08:43 +00:00
|
|
|
if (user.username == username){
|
|
|
|
//This is our user
|
|
|
|
user.time = userData.time
|
|
|
|
user.maxTime = userData.maxTime
|
|
|
|
user.title = userData.title
|
|
|
|
user.lastHeartbeat = (new Date).getTime()
|
|
|
|
user.playerState = userData.playerState
|
|
|
|
user.rawTitle = userData.rawTitle
|
|
|
|
user.clientResponseTime = userData.clientResponseTime
|
|
|
|
user.type = userData.type
|
|
|
|
user.showName = userData.showName
|
|
|
|
return
|
|
|
|
}
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
}
|
2017-04-10 17:08:43 +00:00
|
|
|
function transferHost(roomName){
|
|
|
|
console.log('Transfering the host in the room ' + roomName)
|
2017-04-11 15:51:07 +00:00
|
|
|
var room = ptserver_io.sockets.adapter.rooms[roomName]
|
2017-04-10 17:08:43 +00:00
|
|
|
if (room === undefined){
|
|
|
|
//Room has already been destroyed!
|
|
|
|
return
|
|
|
|
}
|
|
|
|
var oldHost = removeHost(room)
|
|
|
|
if (oldHost === null || oldHost === undefined) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for (var i in room.users){
|
|
|
|
if (room.users[i].username != oldHost.username){
|
|
|
|
//This is a valid user
|
|
|
|
//console.log('Transferred host to ' + room.users[i].username)
|
|
|
|
room.users[i].role = 'host'
|
|
|
|
room.hostUser = room.users[i]
|
|
|
|
room.hostUsername = room.users[i].username
|
|
|
|
return (room.users[i])
|
|
|
|
}
|
|
|
|
}
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
2017-04-10 17:08:43 +00:00
|
|
|
function removeHost(room){
|
|
|
|
if (room === undefined){
|
|
|
|
//Room has already been destroyed!
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for (var i in room.users){
|
|
|
|
if (room.users[i].role == 'host'){
|
|
|
|
room.users[i].role = 'guest'
|
|
|
|
return(room.users[i])
|
|
|
|
}
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
}
|
2017-04-10 17:08:43 +00:00
|
|
|
function removeUser(roomname,username){
|
2017-04-11 15:51:07 +00:00
|
|
|
var room = ptserver_io.sockets.adapter.rooms[roomname]
|
2017-04-10 17:08:43 +00:00
|
|
|
if (room === undefined){
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for (var i in room.users){
|
|
|
|
if (room.users[i].username == username){
|
|
|
|
//This is the user that we need to remove
|
|
|
|
room.users.splice(i,1)
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
}
|
2017-04-10 17:08:43 +00:00
|
|
|
}
|
|
|
|
function getValidUsername(usersarray,wantedname){
|
|
|
|
var tempname = wantedname
|
|
|
|
while (true){
|
|
|
|
//We need to loop through the users list until we create a valid name
|
|
|
|
var found = false;
|
|
|
|
for (var i in usersarray){
|
|
|
|
if (usersarray[i].username == tempname){
|
|
|
|
//console.log(usersarray[i].username + ' == ' + tempname)
|
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (found){
|
|
|
|
//Looks like that username is taken
|
|
|
|
//Check if we've already appended '(x)'
|
|
|
|
if (tempname.indexOf('(') > -1){
|
|
|
|
//we have
|
|
|
|
var value = parseInt(tempname.substring(
|
|
|
|
tempname.indexOf('(')+1,tempname.indexOf(')')))
|
|
|
|
var newvalue = value + 1
|
|
|
|
tempname = tempname.replace('('+value+')','('+newvalue+')')
|
|
|
|
} else {
|
|
|
|
//we haven't
|
|
|
|
tempname = tempname + '(1)'
|
|
|
|
}
|
2017-04-07 05:09:03 +00:00
|
|
|
} else {
|
2017-04-10 17:08:43 +00:00
|
|
|
//This is a valid name!
|
|
|
|
return tempname
|
2017-04-07 05:09:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-10 17:08:43 +00:00
|
|
|
var user = function(){
|
|
|
|
this.username = null;
|
|
|
|
this.role = null;
|
|
|
|
this.room = null;
|
|
|
|
this.title = null;
|
|
|
|
this.time = null;
|
|
|
|
this.avatarUrl = null;
|
|
|
|
}
|
|
|
|
});
|
2017-04-11 15:51:07 +00:00
|
|
|
rootserver.listen(PORT);
|
2017-04-10 17:08:43 +00:00
|
|
|
console.log('PlexTogether Server successfully started on port ' + PORT)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
setInterval(function(){
|
2017-04-11 15:51:07 +00:00
|
|
|
console.log('Connected users: ' + Object.keys(ptserver_io.sockets.connected).length)
|
2017-04-10 17:08:43 +00:00
|
|
|
},5000)
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-04-07 05:09:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
|