diff --git a/back/loaders/server.ts b/back/loaders/server.ts index 6f92b519..19123edf 100644 --- a/back/loaders/server.ts +++ b/back/loaders/server.ts @@ -5,18 +5,34 @@ import Sock from './sock'; export default async ({ server }: { server: Server }) => { await Sock({ server }); Logger.info('✌️ Sock loaded'); + let exitTime = 0; + let timer: NodeJS.Timeout; - process.on('SIGINT', () => { - Logger.info('✌️ Server need close'); - server.close(() => { - setTimeout(() => { - process.exit(); - }, 10000); - }); - - setTimeout(() => { - console.log('Forcing server close !!!'); + process.on('SIGINT', (singal) => { + Logger.warn(`Server need close, singal ${singal}`); + exitTime++; + if (exitTime >= 3) { + Logger.warn('Forcing server close'); + clearTimeout(timer); process.exit(1); - }, 15000); + } + server.close(() => { + if (timer) { + clearTimeout(timer); + } + timer = setTimeout(() => { + process.exit(); + }, 15000); + }); + }); + + process.on('uncaughtException', (error) => { + Logger.error('Uncaught exception:', error); + process.exit(1); + }); + + process.on('unhandledRejection', (reason, promise) => { + Logger.error('Unhandled rejection:', reason); + process.exit(1); }); };