server.ts 1.8 KB

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