use listen(0) to find a port

This commit is contained in:
Jonathan Rainville 2018-08-23 15:11:43 -04:00
parent 7e59b6f0d0
commit b9c65f2d58
2 changed files with 20 additions and 15 deletions

View File

@ -18,13 +18,15 @@ class WebServer {
this.events.emit("status", __("Starting Server")); this.events.emit("status", __("Starting Server"));
this.server = new Server({host: this.host, port: this.port});
this.testPort(() => { this.testPort(() => {
this.server = new Server({host: this.host, port: this.port});
this.setServiceCheck();
this.listenToCommands(); this.listenToCommands();
this.registerConsoleCommands(); this.registerConsoleCommands();
this.server.start((_err, message) => this.logger.info(message)); this.server.start((_err, message, port) => {
this.logger.info(message);
this.port = port;
this.setServiceCheck();
});
}); });
} }
@ -33,17 +35,18 @@ class WebServer {
if (err) { // Port is ok if (err) { // Port is ok
return done(); return done();
} }
this.logger.warn(__('Webserver already running on port {{oldPort}}. Trying to connect on {{newPort}}', this.logger.warn(__('Webserver already running on port %s. Assigning an available port', this.port));
{oldPort: this.port, newPort: this.port + 1})); this.port = 0;
this.port++; this.server.port = 0;
this.testPort(done); done();
}); });
} }
setServiceCheck() { setServiceCheck() {
let url = 'http://' + canonicalHost(this.host) + ':' + this.port; const self = this;
this.events.request("services:register", 'Webserver', function (cb) { this.events.request("services:register", 'Webserver', function (cb) {
let url = 'http://' + canonicalHost(self.host) + ':' + self.port;
utils.checkIsAvailable(url, function (available) { utils.checkIsAvailable(url, function (available) {
let devServer = __('Webserver') + ' (' + url + ')'; let devServer = __('Webserver') + ' (' + url + ')';
let serverStatus = (available ? 'on' : 'off'); let serverStatus = (available ? 'on' : 'off');

View File

@ -24,12 +24,14 @@ class Server {
serve(req, res, finalhandler(req, res)); serve(req, res, finalhandler(req, res));
}).withShutdown(); }).withShutdown();
let message = __("webserver available at") +
" " + this.server.listen(this.port, this.hostname, () => {
("http://" + canonicalHost(this.hostname) + this.port = this.server.address().port;
":" + this.port).bold.underline.green; callback(null, __("webserver available at") +
this.server.listen(this.port, this.hostname); " " +
callback(null, message); ("http://" + canonicalHost(this.hostname) +
":" + this.port).bold.underline.green, this.port);
});
} }
stop(callback) { stop(callback) {