Familienduell/server/server.js
2018-06-22 13:24:12 +02:00

162 lines
4.7 KiB
JavaScript

//Websocket Server <<<<<<<<<<<<<<
var wsPort = 8081;
var webPort = 8080;
var subscribers = [];
var WebSocketServer = require('ws').Server;
var wss = new WebSocketServer({port: wsPort});
var http = require('http');
var url = require('url');
var path = require('path');
var fs = require('fs');
var baseDirectory = '../web/'
http.createServer(function (request, response) {
try {
var rurl = request.url;
if(rurl=="/") {
rurl = "/index.html";
}
var requestUrl = url.parse(rurl)
// need to use path.normalize so people can't access directories underneath baseDirectory
var fsPath = baseDirectory+path.normalize(requestUrl.pathname);
var fileStream = fs.createReadStream(fsPath)
fileStream.pipe(response)
fileStream.on('open', function() {
response.writeHead(200)
})
fileStream.on('error',function(e) {
response.writeHead(404) // assume the file doesn't exist
response.end()
})
} catch(e) {
response.writeHead(500)
response.end() // end the response so browsers don't hang
console.log(e.stack)
}
}).listen(webPort)
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) {
console.log('msg: ' + 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);
}
});
}
}
});
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.split("###")[0]+" length:"+subscribers.length);
for(var i=0;i<subscribers.length;i++) {
if(subscribers[i] != null)
subscribers[i].send(msg);
}
}
console.log("\nWebsocket server running on Port:"+wsPort);
console.log("Webserver running on Port:"+webPort);
console.log("\n---Verbinden von diesem PC---");
console.log(" Browser öffnen und zu Adresse: http://127.0.0.1:"+webPort+" surfen!");
console.log("\n---Adressen zum verbinden von anderen Geräten---");
getLocalIp()
console.log("\n\n------------------------------");
console.log("\n---SERVER IS UP AND RUNNING---");
console.log("\n------------------------------");
function writeInFile(filename, content, callback) {
console.log("going to read file:"+filename);
fs.writeFile(filename, content, function(err) {
console.log("file:"+filename+" write callback done!");
if(err) {
console.log(err);
callback("error");
} else {
callback("success");
console.log("The file '"+filename+"' was saved!");
}
});
}
function readFile(filename, callback) {
console.log("going to read file:"+filename);
fs.readFile(filename, 'utf8', function (err,data) {
console.log("file:"+filename+" read callback done!");
if (err) {
console.log(err);
callback("error");
}
callback(data);
});
}
function getLocalIp() {
var os = require('os');
var ifaces = os.networkInterfaces();
Object.keys(ifaces).forEach(function (ifname) {
var alias = 0;
ifaces[ifname].forEach(function (iface) {
if ('IPv4' !== iface.family || iface.internal !== false) {
// skip over internal (i.e. 127.0.0.1) and non-ipv4 addresses
return;
}
if (alias >= 1) {
// this single interface has multiple ipv4 addresses
console.log(" http://"+iface.address+":"+webPort);
} else {
// this interface has only one ipv4 adress
console.log(" "+ifname+": ", "http://"+iface.address+":"+webPort);
}
++alias;
});
});
}