70 lines
2.1 KiB
TypeScript
70 lines
2.1 KiB
TypeScript
import 'reflect-metadata'
|
|
|
|
import 'newrelic'
|
|
|
|
import * as Sentry from '@sentry/node'
|
|
|
|
import '../src/Infra/InversifyExpressUtils/InversifyExpressHealthCheckController'
|
|
import '../src/Infra/InversifyExpressUtils/InversifyExpressWebSocketsController'
|
|
|
|
import * as cors from 'cors'
|
|
import { urlencoded, json, Request, Response, NextFunction, RequestHandler, ErrorRequestHandler } from 'express'
|
|
import * as winston from 'winston'
|
|
|
|
import { InversifyExpressServer } from 'inversify-express-utils'
|
|
import { ContainerConfigLoader } from '../src/Bootstrap/Container'
|
|
import TYPES from '../src/Bootstrap/Types'
|
|
import { Env } from '../src/Bootstrap/Env'
|
|
|
|
const container = new ContainerConfigLoader()
|
|
void container.load().then((container) => {
|
|
const env: Env = new Env()
|
|
env.load()
|
|
|
|
const server = new InversifyExpressServer(container)
|
|
|
|
server.setConfig((app) => {
|
|
app.use((_request: Request, response: Response, next: NextFunction) => {
|
|
response.setHeader('X-Websockets-Version', container.get(TYPES.VERSION))
|
|
next()
|
|
})
|
|
app.use(json())
|
|
app.use(urlencoded({ extended: true }))
|
|
app.use(cors())
|
|
|
|
if (env.get('SENTRY_DSN', true)) {
|
|
Sentry.init({
|
|
dsn: env.get('SENTRY_DSN'),
|
|
integrations: [new Sentry.Integrations.Http({ tracing: false, breadcrumbs: true })],
|
|
tracesSampleRate: 0,
|
|
})
|
|
|
|
app.use(Sentry.Handlers.requestHandler() as RequestHandler)
|
|
}
|
|
})
|
|
|
|
const logger: winston.Logger = container.get(TYPES.Logger)
|
|
|
|
server.setErrorConfig((app) => {
|
|
if (env.get('SENTRY_DSN', true)) {
|
|
app.use(Sentry.Handlers.errorHandler() as ErrorRequestHandler)
|
|
}
|
|
|
|
app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
|
|
logger.error(error.stack)
|
|
|
|
response.status(500).send({
|
|
error: {
|
|
message:
|
|
"Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
|
|
},
|
|
})
|
|
})
|
|
})
|
|
|
|
const serverInstance = server.build()
|
|
|
|
serverInstance.listen(env.get('PORT'))
|
|
|
|
logger.info(`Server started on port ${process.env.PORT}`)
|
|
})
|