server.ts 1.8 KB

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