72 lines
2.4 KiB
JavaScript
Raw Normal View History

var {canonicalHost} = require('../../utils/host.js');
2017-12-18 09:37:16 -05:00
var utils = require('../../utils/utils.js');
var Server = require('./server.js');
class WebServer {
constructor(embark, options) {
2017-12-29 18:29:56 -05:00
this.embark = embark;
2017-12-18 09:37:16 -05:00
this.logger = embark.logger;
this.events = embark.events;
2018-07-12 16:02:16 +03:00
this.plugins = options.plugins;
2017-12-19 09:50:29 -05:00
this.webServerConfig = embark.config.webServerConfig;
if (!this.webServerConfig.enabled) {
2017-12-18 09:37:16 -05:00
return;
}
2017-12-19 09:50:29 -05:00
this.host = options.host || this.webServerConfig.host;
this.port = options.port || this.webServerConfig.port;
2018-07-13 10:50:57 +03:00
this.enableCatchAll = this.webServerConfig.enableCatchAll === true;
2018-08-27 16:22:53 -04:00
this.enableCatchAll = false; // FIXME when true, some Requests end up failing (eg: process-logs)
2017-12-18 09:37:16 -05:00
2018-05-08 17:49:46 -04:00
this.events.emit("status", __("Starting Server"));
2018-08-27 16:22:53 -04:00
this.server = new Server({logger: this.logger, host: this.host, port: this.port, events: this.events, plugins: this.plugins, enableCatchAll: this.enableCatchAll});
2017-12-19 09:50:29 -05:00
this.setServiceCheck();
this.listenToCommands();
2017-12-29 18:29:56 -05:00
this.registerConsoleCommands();
2017-12-19 09:50:29 -05:00
2018-08-27 16:22:53 -04:00
this.server.start((_err, message) => this.logger.info(message));
2017-12-19 09:50:29 -05:00
}
setServiceCheck() {
let url = 'http://' + canonicalHost(this.host) + ':' + this.port;
2017-12-18 09:37:16 -05:00
this.events.request("services:register", 'Webserver', function (cb) {
2017-12-19 09:50:29 -05:00
utils.checkIsAvailable(url, function (available) {
2018-05-08 17:49:46 -04:00
let devServer = __('Webserver') + ' (' + url + ')';
2017-12-19 09:50:29 -05:00
let serverStatus = (available ? 'on' : 'off');
return cb({name: devServer, status: serverStatus});
2017-12-18 09:37:16 -05:00
});
});
2017-12-19 09:50:29 -05:00
this.events.on('check:wentOffline:Webserver', () => {
2018-05-08 17:49:46 -04:00
this.logger.info(__("Webserver is offline"));
2017-12-18 09:37:16 -05:00
});
2017-12-19 09:50:29 -05:00
}
2017-12-18 09:37:16 -05:00
2017-12-19 09:50:29 -05:00
listenToCommands() {
2018-08-10 15:09:56 +01:00
this.events.setCommandHandler('start-webserver', (callback) => this.server.start(callback));
this.events.setCommandHandler('stop-webserver', (callback) => this.server.stop(callback));
2017-12-18 09:37:16 -05:00
}
2017-12-29 18:29:56 -05:00
registerConsoleCommands() {
const self = this;
2017-12-29 18:33:11 -05:00
self.embark.registerConsoleCommand((cmd, _options) => {
2018-08-08 13:42:45 +01:00
return {
match: () => cmd === "webserver start",
2018-08-10 15:09:56 +01:00
process: (callback) => self.events.request("start-webserver", callback)
};
2017-12-29 18:29:56 -05:00
});
2018-08-08 13:42:45 +01:00
self.embark.registerConsoleCommand((cmd, _options) => {
return {
match: () => cmd === "webserver stop",
2018-08-10 15:09:56 +01:00
process: (callback) => self.events.request("stop-webserver", callback)
2018-08-08 13:42:45 +01:00
};
});
}
2017-12-18 09:37:16 -05:00
}
module.exports = WebServer;