2017-03-30 02:50:05 +09:00
|
|
|
let finalhandler = require('finalhandler');
|
|
|
|
let http = require('http');
|
|
|
|
let serveStatic = require('serve-static');
|
2018-07-26 12:13:18 -05:00
|
|
|
const {canonicalHost, defaultHost, dockerHostSwap} = require('../../utils/host');
|
2017-12-17 18:34:41 -05:00
|
|
|
require('http-shutdown').extend();
|
2018-02-25 19:01:50 -05:00
|
|
|
var express = require('express');
|
|
|
|
let path = require('path');
|
2018-02-26 09:45:46 -05:00
|
|
|
var expressWebSocket = require('express-ws');
|
2016-08-21 11:02:50 -04:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
class Server {
|
|
|
|
constructor(options) {
|
|
|
|
this.dist = options.dist || 'dist/';
|
|
|
|
this.port = options.port || 8000;
|
2018-07-26 12:13:18 -05:00
|
|
|
this.hostname = dockerHostSwap(options.host) || defaultHost;
|
2017-03-30 20:12:39 +09:00
|
|
|
this.logger = options.logger;
|
|
|
|
}
|
2016-08-21 11:02:50 -04:00
|
|
|
|
2017-03-30 20:12:39 +09:00
|
|
|
start(callback) {
|
2018-02-26 09:45:46 -05:00
|
|
|
const self = this;
|
2017-12-17 19:18:35 -05:00
|
|
|
if (this.server && this.server.listening) {
|
2018-07-26 12:13:18 -05:00
|
|
|
this.logger.warn(__("a webserver is already running at") +
|
|
|
|
" " +
|
|
|
|
("http://" + canonicalHost(this.hostname) +
|
|
|
|
":" + this.port).bold.underline.green);
|
2017-12-17 19:18:35 -05:00
|
|
|
if (callback) {
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2017-03-30 20:12:39 +09:00
|
|
|
let serve = serveStatic(this.dist, {'index': ['index.html', 'index.htm']});
|
2016-08-21 11:02:50 -04:00
|
|
|
|
2018-02-25 19:01:50 -05:00
|
|
|
var app = express();
|
|
|
|
|
|
|
|
app.use(serve);
|
|
|
|
app.use('/backend', serveStatic(path.join(__dirname, 'backend'), {'backend': ['index.html', 'index.htm']}));
|
|
|
|
|
2018-02-26 09:45:46 -05:00
|
|
|
expressWebSocket(app);
|
|
|
|
|
|
|
|
app.ws('/logs', function(ws, req) {
|
|
|
|
self.events.on("log", function(logLevel, logMsg) {
|
|
|
|
console.dir("got message " + logMsg);
|
|
|
|
ws.send(logMsg);
|
|
|
|
});
|
|
|
|
ws.on('message', function(msg) {
|
|
|
|
console.dir("got message");
|
|
|
|
console.dir(msg);
|
|
|
|
ws.send(msg);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-02-25 19:01:50 -05:00
|
|
|
//app.get('/embark', function (req, res) {
|
|
|
|
// res.send('Welcome to Embark')
|
|
|
|
//});
|
|
|
|
|
|
|
|
app.listen(this.port);
|
2016-08-21 11:02:50 -04:00
|
|
|
|
2018-07-26 12:13:18 -05:00
|
|
|
this.logger.info(__("webserver available at") +
|
|
|
|
" " +
|
|
|
|
("http://" + canonicalHost(this.hostname) +
|
|
|
|
":" + this.port).bold.underline.green);
|
2017-12-17 18:34:41 -05:00
|
|
|
this.server.listen(this.port, this.hostname);
|
2018-02-25 19:01:50 -05:00
|
|
|
|
|
|
|
//this.server = http.createServer(function onRequest(req, res) {
|
|
|
|
// serve(req, res, finalhandler(req, res));
|
|
|
|
//}).withShutdown();
|
|
|
|
|
|
|
|
//this.logger.info("webserver available at " + ("http://" + this.hostname + ":" + this.port).bold.underline.green);
|
|
|
|
//this.server.listen(this.port, this.hostname);
|
2017-12-17 18:34:41 -05:00
|
|
|
if (callback) {
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
stop(callback) {
|
2017-12-17 19:18:35 -05:00
|
|
|
if (!this.server || !this.server.listening) {
|
2018-05-08 17:49:46 -04:00
|
|
|
this.logger.warn(__("no webserver is currently running"));
|
2017-12-17 19:18:35 -05:00
|
|
|
if (callback) {
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2017-12-17 18:34:41 -05:00
|
|
|
this.server.shutdown(function() {
|
|
|
|
if (callback) {
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
});
|
2017-03-30 20:12:39 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2016-08-21 11:02:50 -04:00
|
|
|
|
|
|
|
module.exports = Server;
|