server.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import 'reflect-metadata'
  2. import 'newrelic'
  3. import * as Sentry from '@sentry/node'
  4. import '../src/Infra/InversifyExpress/InversifyExpressRevisionsController'
  5. import '../src/Infra/InversifyExpress/InversifyExpressHealthCheckController'
  6. import * as cors from 'cors'
  7. import { urlencoded, json, Request, Response, NextFunction, RequestHandler, ErrorRequestHandler } from 'express'
  8. import * as winston from 'winston'
  9. import { InversifyExpressServer } from 'inversify-express-utils'
  10. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  11. import TYPES from '../src/Bootstrap/Types'
  12. import { Env } from '../src/Bootstrap/Env'
  13. const container = new ContainerConfigLoader()
  14. void container.load().then((container) => {
  15. const env: Env = new Env()
  16. env.load()
  17. const server = new InversifyExpressServer(container)
  18. server.setConfig((app) => {
  19. app.use((_request: Request, response: Response, next: NextFunction) => {
  20. response.setHeader('X-Revisions-Version', container.get(TYPES.VERSION))
  21. next()
  22. })
  23. app.use(json())
  24. app.use(urlencoded({ extended: true }))
  25. app.use(cors())
  26. if (env.get('SENTRY_DSN', true)) {
  27. Sentry.init({
  28. dsn: env.get('SENTRY_DSN'),
  29. integrations: [new Sentry.Integrations.Http({ tracing: false, breadcrumbs: true })],
  30. tracesSampleRate: 0,
  31. })
  32. app.use(Sentry.Handlers.requestHandler() as RequestHandler)
  33. }
  34. })
  35. const logger: winston.Logger = container.get(TYPES.Logger)
  36. server.setErrorConfig((app) => {
  37. if (env.get('SENTRY_DSN', true)) {
  38. app.use(Sentry.Handlers.errorHandler() as ErrorRequestHandler)
  39. }
  40. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  41. logger.error(error.stack)
  42. response.status(500).send({
  43. error: {
  44. message:
  45. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  46. },
  47. })
  48. })
  49. })
  50. const serverInstance = server.build()
  51. serverInstance.listen(env.get('PORT'))
  52. logger.info(`Server started on port ${process.env.PORT}`)
  53. })