let finalhandler = require('finalhandler'); let http = require('http'); let serveStatic = require('serve-static'); const {canonicalHost, defaultHost, dockerHostSwap} = require('../../utils/host'); require('http-shutdown').extend(); var express = require('express'); let path = require('path'); var expressWebSocket = require('express-ws'); class Server { constructor(options) { this.events = options.events; this.dist = options.dist || 'dist/'; this.port = options.port || 8000; this.hostname = dockerHostSwap(options.host) || defaultHost; } start(callback) { const self = this; if (this.server && this.server.listening) { let message = __("a webserver is already running at") + " " + ("http://" + canonicalHost(this.hostname) + ":" + this.port).bold.underline.green; return callback(null, message); } let serve = serveStatic(this.dist, {'index': ['index.html', 'index.htm']}); var app = express(); app.use(serve); app.use('/embark', serveStatic(path.join(__dirname, 'backend'), {'backend': ['index.html', 'index.htm']})); expressWebSocket(app); app.ws('/embark/logs', function(ws, req) { self.events.on("log", function(logLevel, logMsg) { ws.send(JSON.stringify({msg: logMsg, msg_clear: logMsg.stripColors, logLevel: logLevel}), () => {}); }); ws.on('message', function(msg) { console.dir("got message"); console.dir(msg); ws.send(msg, () => {}); }); }); app.get('/embark', function (req, res) { res.send('Welcome to Embark') }); app.listen(this.port); let message = __("webserver available at") + " " + ("http://" + canonicalHost(this.hostname) + ":" + this.port).bold.underline.green; this.server.listen(this.port, this.hostname); callback(null, message); } stop(callback) { if (!this.server || !this.server.listening) { return callback(null, __("no webserver is currently running")); } this.server.shutdown(function() { callback(null, __("Webserver stopped")); }); } } module.exports = Server;