Ability to choose which protocol to use (Websocket or WebRTC) with Netflux
This commit is contained in:
35
WebRTCSrv.js
35
WebRTCSrv.js
@@ -1,11 +1,10 @@
|
||||
'use strict'
|
||||
let WebSocketServer = require('ws').Server
|
||||
const PORT = 8000
|
||||
const UNSUPPORTED_DATA = 1007
|
||||
const POLICY_VIOLATION = 1008
|
||||
const CLOSE_UNSUPPORTED = 1003
|
||||
|
||||
var run = module.exports.run = function(storage, server) {
|
||||
var run = module.exports.run = function(server) {
|
||||
server.on('connection', (socket) => {
|
||||
socket.on('message', (data) => {
|
||||
try {
|
||||
@@ -15,7 +14,6 @@ var run = module.exports.run = function(storage, server) {
|
||||
for (let master of server.clients) {
|
||||
if (master.key === msg.key) {
|
||||
socket.close(POLICY_VIOLATION, 'The key already exists')
|
||||
console.log('ERROR key exists');
|
||||
return
|
||||
}
|
||||
}
|
||||
@@ -32,16 +30,13 @@ var run = module.exports.run = function(storage, server) {
|
||||
} else if (msg.hasOwnProperty('join')) {
|
||||
for (let master of server.clients) {
|
||||
if (master.key === msg.join) {
|
||||
console.log('joined');
|
||||
socket.master = master
|
||||
master.joiningClients.push(socket)
|
||||
let id = master.joiningClients.length - 1
|
||||
console.log(id);
|
||||
master.send(JSON.stringify({id, data: msg.data}))
|
||||
return
|
||||
}
|
||||
}
|
||||
console.log('ERROR unknown key');
|
||||
socket.close(POLICY_VIOLATION, 'Unknown key')
|
||||
} else if (msg.hasOwnProperty('data') && socket.hasOwnProperty('master')) {
|
||||
let id = socket.master.joiningClients.indexOf(socket)
|
||||
@@ -55,31 +50,11 @@ var run = module.exports.run = function(storage, server) {
|
||||
})
|
||||
|
||||
socket.on('close', (event) => {
|
||||
console.log('someone has closed');
|
||||
// If not master
|
||||
if (socket.hasOwnProperty('master')) {
|
||||
let masterClients = socket.master.joiningClients
|
||||
for (let client of masterClients) {
|
||||
if(client.id === socket.id) {
|
||||
console.log('close client '+client.key)
|
||||
client.close(POLICY_VIOLATION, 'The peer is no longer available')
|
||||
//masterClients.splice(masterClients.indexOf(client),1);
|
||||
}
|
||||
if (socket.hasOwnProperty('joiningClients')) {
|
||||
for (let client of socket.joiningClients) {
|
||||
client.close(POLICY_VIOLATION, 'The peer is no longer available')
|
||||
}
|
||||
}
|
||||
else if (socket.hasOwnProperty('joiningClients')) {
|
||||
let firstClient
|
||||
let masterClients = socket.joiningClients
|
||||
for (let client of masterClients) {
|
||||
firstClient = client
|
||||
break;
|
||||
}
|
||||
firstClient.close(POLICY_VIOLATION, 'The master is no longer available')
|
||||
//masterClients.splice(masterClients.indexOf(firstClient),1);
|
||||
firstClient.joiningClients = masterClients
|
||||
console.log('change master from '+socket.key+' to '+firstClient.key)
|
||||
socket = firstClient
|
||||
}
|
||||
})
|
||||
});
|
||||
})
|
||||
}
|
||||
Reference in New Issue
Block a user