Familienduell/server/server.js
2015-04-22 14:05:50 +02:00

97 lines
2.5 KiB
JavaScript

//Websocket Server <<<<<<<<<<<<<<
var wsPort = 8080;
var subscribers = [];
var WebSocketServer = require('ws').Server
, wss = new WebSocketServer({port: wsPort});
var fs = require('fs');
wss.on('connection', function(ws) {
subscribers.push(ws);
ws.send(subscribers.length-1 + '###thatsYou');
for(var i=0;i<subscribers.length;i++) {
if(subscribers[i] != null)
broadcastMessage(i, "connected");
}
console.log("~~~~~~~~ WELCOME TO SERVER ~~~~~~ s:"+subscribers.length);
ws.on('message', function(message) {
var parts = message.split("###");
if(parts[0] != "fileOp") {
broadcastMessage(getClientId(), message);
} else {
if(parts[1] == "write")
writeInFile(parts[2], parts[3], function(ret) {
if(ret == "error") {
broadcastMessage(getClientId(), "error###Fehler beim Schreiben einer Datei... siehe Serverlog!");
} else {
broadcastMessage(getClientId(), "file###"+parts[2]+"###"+parts[3]);
}
});
else if(parts[1] == "read") {
readFile(parts[2], function(content) {
if(content == "error") {
broadcastMessage(getClientId(), "error###Fehler beim Lesen einer Datei... siehe Serverlog!");
} else {
broadcastMessage(getClientId(), "file###"+parts[2]+"###"+content);
}
});
}
}
console.log('msg: ' + message);
});
ws.on("close", function() {
var cId = getClientId();
subscribers[cId] = null;
broadcastMessage(cId, "disconnected");
console.log('Subscriber left: ' + subscribers.length + " total.\n");
});
function getClientId() {
for(var i=0;i<subscribers.length;i++) {
if(subscribers[i] == ws)
return i;
}
}
});
function broadcastMessage(clientId, msg) {
//console.log("broadcast:"+msg+" length:"+subscribers.length);
for(var i=0;i<subscribers.length;i++) {
if(subscribers[i] != null)
subscribers[i].send(msg);
}
}
console.log("Websocket Server running at ws://127.0.0.1:"+wsPort);
//Show NODEJS errors
process.on('uncaughtException', function (err) {
console.log('Caught exception: ' + err);
});
function writeInFile(filename, content, callback) {
fs.writeFile(filename, content, function(err) {
if(err) {
console.log(err);
callback("error");
} else {
callback("success");
console.log("The file '"+filename+"' was saved!");
}
});
}
function readFile(filname, callback) {
fs.readFile(filname, 'utf8', function (err,data) {
if (err) {
console.log(err);
callback("error");
}
callback(data);
});
}