server.ts 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import 'reflect-metadata'
  2. import 'newrelic'
  3. import * as Sentry from '@sentry/node'
  4. import '../src/Controller/HealthCheckController'
  5. import '../src/Controller/SessionController'
  6. import '../src/Controller/SessionsController'
  7. import '../src/Controller/UsersController'
  8. import '../src/Controller/SettingsController'
  9. import '../src/Controller/FeaturesController'
  10. import '../src/Controller/WebSocketsController'
  11. import '../src/Controller/AdminController'
  12. import '../src/Controller/InternalController'
  13. import '../src/Controller/SubscriptionTokensController'
  14. import '../src/Controller/OfflineController'
  15. import '../src/Controller/ValetTokenController'
  16. import '../src/Controller/ListedController'
  17. import '../src/Controller/SubscriptionInvitesController'
  18. import '../src/Controller/SubscriptionSettingsController'
  19. import '../src/Infra/InversifyExpressUtils/InversifyExpressAuthController'
  20. import * as cors from 'cors'
  21. import { urlencoded, json, Request, Response, NextFunction, RequestHandler, ErrorRequestHandler } from 'express'
  22. import * as winston from 'winston'
  23. import * as dayjs from 'dayjs'
  24. import * as utc from 'dayjs/plugin/utc'
  25. import { InversifyExpressServer } from 'inversify-express-utils'
  26. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  27. import TYPES from '../src/Bootstrap/Types'
  28. import { Env } from '../src/Bootstrap/Env'
  29. const container = new ContainerConfigLoader()
  30. void container.load().then((container) => {
  31. dayjs.extend(utc)
  32. const env: Env = new Env()
  33. env.load()
  34. const server = new InversifyExpressServer(container)
  35. server.setConfig((app) => {
  36. app.use((_request: Request, response: Response, next: NextFunction) => {
  37. response.setHeader('X-Auth-Version', container.get(TYPES.VERSION))
  38. next()
  39. })
  40. app.use(json())
  41. app.use(urlencoded({ extended: true }))
  42. app.use(cors())
  43. if (env.get('SENTRY_DSN', true)) {
  44. Sentry.init({
  45. dsn: env.get('SENTRY_DSN'),
  46. integrations: [new Sentry.Integrations.Http({ tracing: false, breadcrumbs: true })],
  47. tracesSampleRate: 0,
  48. })
  49. app.use(Sentry.Handlers.requestHandler() as RequestHandler)
  50. }
  51. })
  52. const logger: winston.Logger = container.get(TYPES.Logger)
  53. server.setErrorConfig((app) => {
  54. if (env.get('SENTRY_DSN', true)) {
  55. app.use(Sentry.Handlers.errorHandler() as ErrorRequestHandler)
  56. }
  57. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  58. logger.error(error.stack)
  59. response.status(500).send({
  60. error: {
  61. message:
  62. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  63. },
  64. })
  65. })
  66. })
  67. const serverInstance = server.build()
  68. serverInstance.listen(env.get('PORT'))
  69. logger.info(`Server started on port ${process.env.PORT}`)
  70. })