53 lines
1.4 KiB
JavaScript
Raw Normal View History

2017-03-30 02:50:05 +09:00
let finalhandler = require('finalhandler');
let http = require('http');
let serveStatic = require('serve-static');
2017-12-17 18:34:41 -05:00
require('http-shutdown').extend();
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;
this.hostname = options.host || 'localhost';
this.logger = options.logger;
}
2016-08-21 11:02:50 -04:00
2017-03-30 20:12:39 +09:00
start(callback) {
if (this.server && this.server.listening) {
2018-05-08 17:49:46 -04:00
this.logger.warn(__("a webserver is already running at") + " " + ("http://" + this.hostname + ":" + this.port).bold.underline.green);
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
2017-12-17 18:34:41 -05:00
this.server = http.createServer(function onRequest(req, res) {
2017-03-30 20:12:39 +09:00
serve(req, res, finalhandler(req, res));
2017-12-17 18:34:41 -05:00
}).withShutdown();
2016-08-21 11:02:50 -04:00
2018-05-08 17:49:46 -04:00
this.logger.info(__("webserver available at") + " " + ("http://" + this.hostname + ":" + this.port).bold.underline.green);
2017-12-17 18:34:41 -05:00
this.server.listen(this.port, this.hostname);
if (callback) {
callback();
}
}
stop(callback) {
if (!this.server || !this.server.listening) {
2018-05-08 17:49:46 -04:00
this.logger.warn(__("no webserver is currently running"));
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;