bin/www.ts
/* eslint-disable no-process-exit, unicorn/no-process-exit */
import { app } from "../app.js";
import http from "http";
import * as configFunctions from "../helpers/configFunctions.js";
import exitHook from "exit-hook";
import debug from "debug";
const debugWWW = debug("contract-expiration-tracker:www");
let httpServer: http.Server;
interface ServerError extends Error {
syscall: string;
code: string;
}
const onError = (error: ServerError) => {
if (error.syscall !== "listen") {
throw error;
}
// handle specific listen errors with friendly messages
switch (error.code) {
case "EACCES":
debugWWW("Requires elevated privileges");
process.exit(1);
// break;
case "EADDRINUSE":
debugWWW("Port is already in use.");
process.exit(1);
// break;
default:
throw error;
}
};
const onListening = (server: http.Server) => {
const addr = server.address();
const bind = typeof addr === "string"
? "pipe " + addr
: "port " + addr.port.toString();
debugWWW("Listening on " + bind);
};
/**
* Initialize HTTP
*/
const httpPort = configFunctions.getProperty("application.httpPort");
if (httpPort) {
httpServer = http.createServer(app);
httpServer.listen(httpPort);
httpServer.on("error", onError);
httpServer.on("listening", function() {
onListening(httpServer);
});
debugWWW("HTTP listening on " + httpPort.toString());
}
exitHook(() => {
if (httpServer) {
debugWWW("Closing HTTP");
httpServer.close();
httpServer = undefined;
}
});