server.ts 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. import 'reflect-metadata'
  2. import '../src/Infra/InversifyExpressUtils/AnnotatedHealthCheckController'
  3. import '../src/Infra/InversifyExpressUtils/AnnotatedItemsController'
  4. import '../src/Infra/InversifyExpressUtils/AnnotatedMessagesController'
  5. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultInvitesController'
  6. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultUsersController'
  7. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultsController'
  8. import helmet from 'helmet'
  9. import * as cors from 'cors'
  10. import { urlencoded, json, Request, Response, NextFunction } from 'express'
  11. import * as winston from 'winston'
  12. import { InversifyExpressServer } from 'inversify-express-utils'
  13. import TYPES from '../src/Bootstrap/Types'
  14. import { Env } from '../src/Bootstrap/Env'
  15. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  16. const container = new ContainerConfigLoader()
  17. void container.load().then((container) => {
  18. const env: Env = new Env()
  19. env.load()
  20. const server = new InversifyExpressServer(container)
  21. server.setConfig((app) => {
  22. app.use((_request: Request, response: Response, next: NextFunction) => {
  23. response.setHeader('X-SSJS-Version', container.get(TYPES.Sync_VERSION))
  24. next()
  25. })
  26. /* eslint-disable */
  27. app.use(helmet({
  28. contentSecurityPolicy: {
  29. directives: {
  30. defaultSrc: ["https: 'self'"],
  31. baseUri: ["'self'"],
  32. childSrc: ["*", "blob:"],
  33. connectSrc: ["*"],
  34. fontSrc: ["*", "'self'"],
  35. formAction: ["'self'"],
  36. frameAncestors: ["*", "*.standardnotes.org"],
  37. frameSrc: ["*", "blob:"],
  38. imgSrc: ["'self'", "*", "data:"],
  39. manifestSrc: ["'self'"],
  40. mediaSrc: ["'self'"],
  41. objectSrc: ["'self'"],
  42. scriptSrc: ["'self'"],
  43. styleSrc: ["'self'"]
  44. }
  45. }
  46. }))
  47. /* eslint-enable */
  48. app.use(json({ limit: '50mb' }))
  49. app.use(urlencoded({ extended: true, limit: '50mb', parameterLimit: 5000 }))
  50. app.use(cors())
  51. })
  52. const logger: winston.Logger = container.get(TYPES.Sync_Logger)
  53. server.setErrorConfig((app) => {
  54. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  55. logger.error(error.stack)
  56. response.status(500).send({
  57. error: {
  58. message:
  59. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  60. },
  61. })
  62. })
  63. })
  64. const serverInstance = server.build()
  65. serverInstance.listen(env.get('PORT'))
  66. logger.info(`Server started on port ${process.env.PORT}`)
  67. })