mirror of
https://github.com/bluewave-labs/Checkmate.git
synced 2026-04-28 04:29:27 -05:00
35 lines
785 B
JavaScript
35 lines
785 B
JavaScript
import { logger } from "./utils/logger.js";
|
|
|
|
export const initShutdownListener = (server, services) => {
|
|
const SERVICE_NAME = "Server";
|
|
|
|
let isShuttingDown = false;
|
|
|
|
const shutdown = async () => {
|
|
if (isShuttingDown) {
|
|
return;
|
|
}
|
|
isShuttingDown = true;
|
|
logger.info({ message: "Attempting graceful shutdown" });
|
|
|
|
try {
|
|
server.close();
|
|
await services.jobQueue.shutdown();
|
|
await services.db.disconnect();
|
|
logger.info({ message: "Graceful shutdown complete" });
|
|
process.exit(0);
|
|
} catch (error) {
|
|
logger.error({
|
|
message: error.message,
|
|
service: SERVICE_NAME,
|
|
method: "shutdown",
|
|
stack: error.stack,
|
|
});
|
|
process.exit(1);
|
|
}
|
|
};
|
|
process.on("SIGUSR2", shutdown);
|
|
process.on("SIGINT", shutdown);
|
|
process.on("SIGTERM", shutdown);
|
|
};
|