12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- import 'reflect-metadata'
- import 'newrelic'
- import * as Sentry from '@sentry/node'
- import '../src/Infra/InversifyExpress/InversifyExpressRevisionsController'
- import '../src/Infra/InversifyExpress/InversifyExpressHealthCheckController'
- 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-Revisions-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}`)
- })
|