mirror of
https://github.com/EvolutionAPI/evolution-api.git
synced 2025-07-14 01:41:24 -06:00
134 lines
3.9 KiB
TypeScript
134 lines
3.9 KiB
TypeScript
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>('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>('CORS').METHODS],
|
|
credentials: configService.get<Cors>('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>('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<HttpServer>('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>('RABBITMQ').ENABLED) initAMQP();
|
|
|
|
onUnexpectedError();
|
|
}
|
|
|
|
bootstrap();
|