import 'express-async-errors'; import axios from 'axios'; import compression from 'compression'; import cors from 'cors'; import express, { json, NextFunction, Request, Response, urlencoded } from 'express'; import { join } from 'path'; import { configService, Cors, HttpServer, Rabbitmq, Webhook } from './config/env.config'; import { onUnexpectedError } from './config/error.config'; import { Logger } from './config/logger.config'; import { ROOT_DIR } from './config/path.config'; import { initAMQP } from './libs/amqp.server'; import { initIO } from './libs/socket.server'; import { ServerUP } from './utils/server-up'; import { HttpStatus, router } from './whatsapp/routers/index.router'; import { waMonitor } from './whatsapp/whatsapp.module'; function initWA() { waMonitor.loadInstance(); } function bootstrap() { const logger = new Logger('SERVER'); const app = express(); app.use( cors({ origin(requestOrigin, callback) { const { ORIGIN } = configService.get('CORS'); if (ORIGIN.includes('*')) { return callback(null, true); } if (ORIGIN.indexOf(requestOrigin) !== -1) { return callback(null, true); } return callback(new Error('Not allowed by CORS')); }, methods: [...configService.get('CORS').METHODS], credentials: configService.get('CORS').CREDENTIALS, }), urlencoded({ extended: true, limit: '136mb' }), json({ limit: '136mb' }), compression(), ); app.set('view engine', 'hbs'); app.set('views', join(ROOT_DIR, 'views')); app.use(express.static(join(ROOT_DIR, 'public'))); app.use('/store', express.static(join(ROOT_DIR, 'store'))); app.use('/', router); app.use( (err: Error, req: Request, res: Response, next: NextFunction) => { if (err) { const webhook = configService.get('WEBHOOK'); if (webhook.EVENTS.ERRORS_WEBHOOK && webhook.EVENTS.ERRORS_WEBHOOK != '' && webhook.EVENTS.ERRORS) { const tzoffset = new Date().getTimezoneOffset() * 60000; //offset in milliseconds const localISOTime = new Date(Date.now() - tzoffset).toISOString(); const now = localISOTime; const errorData = { event: 'error', data: { error: err['error'] || 'Internal Server Error', message: err['message'] || 'Internal Server Error', status: err['status'] || 500, response: { message: err['message'] || 'Internal Server Error', }, }, date_time: now, }; logger.error(errorData); const baseURL = webhook.EVENTS.ERRORS_WEBHOOK; const httpService = axios.create({ baseURL }); httpService.post('', errorData); } if (err['message'].includes('No sessions')) { console.log(err['message']); process.exit(1); } return res.status(err['status'] || 500).json({ status: err['status'] || 500, error: err['error'] || 'Internal Server Error', response: { message: err['message'] || 'Internal Server Error', }, }); } next(); }, (req: Request, res: Response, next: NextFunction) => { const { method, url } = req; res.status(HttpStatus.NOT_FOUND).json({ status: HttpStatus.NOT_FOUND, error: 'Not Found', response: { message: [`Cannot ${method.toUpperCase()} ${url}`], }, }); next(); }, ); const httpServer = configService.get('SERVER'); ServerUP.app = app; const server = ServerUP[httpServer.TYPE]; server.listen(httpServer.PORT, () => logger.log(httpServer.TYPE.toUpperCase() + ' - ON: ' + httpServer.PORT)); initWA(); initIO(server); if (configService.get('RABBITMQ').ENABLED) initAMQP(); onUnexpectedError(); } bootstrap();