2022-02-13 14:03:04 +01:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Module dependencies.
|
|
|
|
*/
|
|
|
|
|
2022-02-13 18:07:53 +01:00
|
|
|
import debugLib from "debug";
|
|
|
|
import http from "http";
|
|
|
|
import app from "../app";
|
|
|
|
import { port } from "../config";
|
2022-02-13 14:03:04 +01:00
|
|
|
|
2022-02-17 09:37:25 +01:00
|
|
|
const debug = debugLib("mymusiclibrary:server");
|
2022-02-13 14:03:04 +01:00
|
|
|
const server = http.createServer(app);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Event listener for HTTP server "error" event.
|
|
|
|
* @param {*} error
|
|
|
|
*/
|
|
|
|
function onError(error) {
|
2022-02-13 18:07:53 +01:00
|
|
|
if (error.syscall !== "listen") {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
const bind = typeof port === "string" ? `Pipe ${port}` : `Port ${port}`;
|
|
|
|
|
|
|
|
switch (error.code) {
|
|
|
|
case "EACCES":
|
|
|
|
console.error(`${bind} requires elevated privileges`);
|
|
|
|
process.exit(1);
|
|
|
|
break;
|
|
|
|
case "EADDRINUSE":
|
|
|
|
console.error(`${bind} is already in use`);
|
|
|
|
process.exit(1);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
throw error;
|
|
|
|
}
|
2022-02-13 14:03:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Event listener for HTTP server "listening" event.
|
|
|
|
*/
|
|
|
|
function onListening() {
|
2022-02-13 18:07:53 +01:00
|
|
|
const addr = server.address();
|
|
|
|
const bind =
|
|
|
|
typeof addr === "string" ? `pipe ${addr}` : `port ${addr.port}`;
|
|
|
|
debug(`Listening on ${bind}`);
|
2022-02-13 14:03:04 +01:00
|
|
|
}
|
|
|
|
|
2022-02-13 18:07:53 +01:00
|
|
|
server.listen(port);
|
|
|
|
server.on("error", onError);
|
|
|
|
server.on("listening", onListening);
|