0
0
mirror of https://github.com/sp-tarkov/server.git synced 2025-02-13 09:50:43 -05:00
server/project/src/ErrorHandler.ts

36 lines
1.2 KiB
TypeScript
Raw Normal View History

import readline from "node:readline";
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
import { AsyncQueue } from "@spt-aki/utils/AsyncQueue";
import { UUidGenerator } from "@spt-aki/utils/UUidGenerator";
import { WinstonMainLogger } from "@spt-aki/utils/logging/WinstonMainLogger";
2023-03-03 15:23:46 +00:00
export class ErrorHandler
{
private logger: ILogger;
2023-03-03 15:23:46 +00:00
private readLine: readline.Interface;
constructor()
{
this.logger = new WinstonMainLogger(new AsyncQueue(), new UUidGenerator());
this.readLine = readline.createInterface({
input: process.stdin,
output: process.stdout
});
}
public handleCriticalError(err: Error): void
2023-03-03 15:23:46 +00:00
{
this.logger.error("The application had a critical error and failed to run");
this.logger.error(`Exception produced: ${err.name}`);
2023-03-03 15:23:46 +00:00
if (err.stack)
{
this.logger.error(`\nStacktrace:\n${err.stack}`);
}
2023-03-03 15:23:46 +00:00
// eslint-disable-next-line @typescript-eslint/no-unused-vars
this.readLine.question("Press Enter to close the window", (_ans) => this.readLine.close());
this.readLine.on("close", () => process.exit(1));
2023-03-03 15:23:46 +00:00
}
}