165 lines
5.1 KiB
JavaScript
Raw Normal View History

const async = require('async');
2017-03-30 02:50:05 +09:00
let serveStatic = require('serve-static');
const {canonicalHost, defaultHost, dockerHostSwap} = require('../../utils/host');
2018-09-19 19:19:37 -04:00
const expressWebSocket = require('express-ws');
2018-09-18 14:28:17 +01:00
const express = require('express');
const fs = require('../../core/fs');
2017-12-17 18:34:41 -05:00
require('http-shutdown').extend();
var express = require('express');
2018-08-01 12:53:37 -04:00
var cors = require('cors');
let path = require('path');
2018-02-26 09:45:46 -05:00
var expressWebSocket = require('express-ws');
2018-03-13 06:46:58 -04:00
var bodyParser = require('body-parser');
2018-07-31 17:01:46 -04:00
var fs = require('../../core/fs.js');
2016-08-21 11:02:50 -04:00
2017-03-30 20:12:39 +09:00
class Server {
constructor(options) {
this.logger = options.logger;
this.buildDir = options.buildDir;
this.events = options.events;
2017-03-30 20:12:39 +09:00
this.port = options.port || 8000;
this.hostname = dockerHostSwap(options.host) || defaultHost;
this.isFirstStart = true;
this.opened = false;
this.openBrowser = options.openBrowser;
2018-09-29 00:41:26 +05:30
this.logging = false;
this.events.once('outputDone', () => {
this.logger.info(this._getMessage());
});
2018-09-29 00:41:26 +05:30
}
enableLogging(callback) {
this.logging = true;
return callback(null, __("Enabled Webserver Logs"));
}
disableLogging(callback) {
this.logging = false;
return callback(null, __("Disabled Webserver Logs"));
2017-03-30 20:12:39 +09:00
}
2016-08-21 11:02:50 -04:00
2017-03-30 20:12:39 +09:00
start(callback) {
2018-09-19 19:19:37 -04:00
const self = this;
if (this.server && this.server.listening) {
2018-08-10 15:09:56 +01:00
let message = __("a webserver is already running at") + " " +
2018-08-31 15:02:05 -05:00
("http://" + canonicalHost(this.hostname) +
":" + this.port).bold.underline.green;
2018-08-10 15:09:56 +01:00
return callback(null, message);
}
2016-08-21 11:02:50 -04:00
2018-09-18 14:28:17 +01:00
const coverage = serveStatic(fs.dappPath('coverage/__root__/'), {'index': ['index.html', 'index.htm']});
const coverageStyle = serveStatic(fs.dappPath('coverage/'));
const main = serveStatic(this.buildDir, {'index': ['index.html', 'index.htm']});
this.app = express();
2018-09-27 11:16:55 +01:00
const expressWs = expressWebSocket(this.app);
2018-09-29 00:41:26 +05:30
// Assign Logging Function
this.app.use(function(req, res, next) {
if (self.logging) {
if (!req.headers.upgrade) {
console.log('Webserver> ' + req.method + " " + req.originalUrl);
}
}
next();
});
2018-09-18 14:28:17 +01:00
this.app.use(main);
2018-08-01 11:14:02 -04:00
this.app.use(cors());
2018-09-18 14:28:17 +01:00
this.app.use('/coverage', coverage);
this.app.use(coverageStyle);
2016-08-21 11:02:50 -04:00
2018-08-01 10:19:11 +01:00
this.app.use(express.static(path.join(fs.dappPath(this.dist)), {'index': ['index.html', 'index.htm']}));
this.app.use('/embark', express.static(path.join(__dirname, '../../../embark-ui/build')));
2018-03-13 06:46:58 -04:00
app.use(bodyParser.json()); // support json encoded bodies
2018-08-01 11:14:02 -04:00
app.use(bodyParser.urlencoded({extended: true})); // support encoded bodies
2018-03-13 06:46:58 -04:00
2018-02-26 09:45:46 -05:00
expressWebSocket(this.app);
2018-09-27 11:16:55 +01:00
2018-02-26 09:45:46 -05:00
this.app.ws('/logs', function(ws, req) {
self.events.on("log", function(logLevel, logMsg) {
ws.send(JSON.stringify({msg: logMsg, msg_clear: logMsg.stripColors, logLevel: logLevel}), () => {});
2018-02-26 09:45:46 -05:00
});
2018-03-10 13:12:22 -05:00
});
2018-07-16 09:50:59 +03:00
if (self.plugins) {
let apiCalls = self.plugins.getPluginsProperty("apiCalls", "apiCalls");
for (let apiCall of apiCalls) {
console.dir("adding " + apiCall.method + " " + apiCall.endpoint);
app[apiCall.method].apply(app, [apiCall.endpoint, apiCall.cb]);
}
}
2018-10-03 15:28:00 +01:00
2018-02-26 09:45:46 -05:00
this.app.ws('/', function(ws, _req) {
self.events.on('outputDone', () => {
if (ws.readyState === WEB_SOCKET_STATE_OPEN) {
return ws.send('outputDone');
}
// if the socket wasn't yet opened, listen for the 'open' event,
// then send the 'outputDone' data
ws.addEventListener('open', _event => {
ws.send('outputDone');
});
2018-08-02 12:45:59 -04:00
});
});
2018-08-01 10:19:11 +01:00
this.app.get('/embark/*', function (req, res) {
self.logger.trace('webserver> GET ' + req.path);
res.sendFile(path.join(__dirname, '../../../embark-ui/build', 'index.html'));
2018-09-19 19:19:37 -04:00
});
2018-08-23 15:11:43 -04:00
2018-07-13 10:50:57 +03:00
if (this.enableCatchAll === true) {
2018-08-01 10:19:11 +01:00
this.app.get('/*', function (req, res) {
2018-07-13 10:50:57 +03:00
self.logger.trace('webserver> GET ' + req.path);
res.sendFile(path.join(fs.dappPath(self.dist, 'index.html')));
}
}
async.waterfall([
function createPlaceholderPage(next) {
if (!self.isFirstStart) {
return next();
}
self.isFirstStart = false;
self.events.request('build-placeholder', next);
},
function listen(next) {
2018-09-18 14:28:17 +01:00
self.server = self.app.listen(self.port, self.hostname, () => {
self.port = self.server.address().port;
next();
});
},
function openBrowser(next) {
if (!self.openBrowser || self.opened) {
return next();
}
2018-09-04 08:20:58 -05:00
self.opened = true;
self.events.request('open-browser', next);
}
2018-09-04 08:20:58 -05:00
], function (err) {
if (err) {
return callback(err);
}
callback(null, self._getMessage(), self.port);
2018-09-04 08:20:58 -05:00
});
2017-12-17 18:34:41 -05:00
}
_getMessage() {
return __('webserver available at') + ' ' +
('http://' + canonicalHost(this.hostname) + ':' + this.port).bold.underline.green;
}
2017-12-17 18:34:41 -05:00
stop(callback) {
if (!this.server || !this.server.listening) {
2018-08-10 15:09:56 +01:00
return callback(null, __("no webserver is currently running"));
}
2018-09-18 14:28:17 +01:00
this.server.close(function() {
2018-08-10 15:09:56 +01:00
callback(null, __("Webserver stopped"));
2017-12-17 18:34:41 -05:00
});
2017-03-30 20:12:39 +09:00
}
}
2016-08-21 11:02:50 -04:00
module.exports = Server;