server.ts 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import 'reflect-metadata'
  2. import '../src/Infra/InversifyExpressUtils/AnnotatedHealthCheckController'
  3. import '../src/Infra/InversifyExpressUtils/AnnotatedWebSocketsController'
  4. import * as cors from 'cors'
  5. import { urlencoded, json, Request, Response, NextFunction } from 'express'
  6. import * as winston from 'winston'
  7. import { InversifyExpressServer } from 'inversify-express-utils'
  8. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  9. import TYPES from '../src/Bootstrap/Types'
  10. import { Env } from '../src/Bootstrap/Env'
  11. const container = new ContainerConfigLoader()
  12. void container.load().then((container) => {
  13. const env: Env = new Env()
  14. env.load()
  15. const server = new InversifyExpressServer(container)
  16. server.setConfig((app) => {
  17. app.use((_request: Request, response: Response, next: NextFunction) => {
  18. response.setHeader('X-Websockets-Version', container.get(TYPES.VERSION))
  19. next()
  20. })
  21. app.use(json())
  22. app.use(urlencoded({ extended: true }))
  23. app.use(cors())
  24. })
  25. const logger: winston.Logger = container.get(TYPES.Logger)
  26. server.setErrorConfig((app) => {
  27. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  28. logger.error(error.stack)
  29. response.status(500).send({
  30. error: {
  31. message:
  32. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  33. },
  34. })
  35. })
  36. })
  37. const serverInstance = server.build()
  38. serverInstance.listen(env.get('PORT'))
  39. logger.info(`Server started on port ${process.env.PORT}`)
  40. })