server.ts 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import 'reflect-metadata'
  2. import * as busboy from 'connect-busboy'
  3. import '../src/Infra/InversifyExpress/InversifyExpressHealthCheckController'
  4. import '../src/Infra/InversifyExpress/InversifyExpressFilesController'
  5. import '../src/Infra/InversifyExpress/InversifyExpressSharedVaultFilesController'
  6. import helmet from 'helmet'
  7. import * as cors from 'cors'
  8. import { urlencoded, json, raw, Request, Response, NextFunction } from 'express'
  9. import * as winston from 'winston'
  10. // eslint-disable-next-line @typescript-eslint/no-var-requires
  11. const robots = require('express-robots-txt')
  12. import { InversifyExpressServer } from 'inversify-express-utils'
  13. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  14. import TYPES from '../src/Bootstrap/Types'
  15. import { Env } from '../src/Bootstrap/Env'
  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-Files-Version', container.get(TYPES.Files_VERSION))
  24. next()
  25. })
  26. app.use(
  27. busboy({
  28. highWaterMark: 2 * 1024 * 1024,
  29. }),
  30. )
  31. /* eslint-disable */
  32. app.use(helmet({
  33. contentSecurityPolicy: {
  34. directives: {
  35. defaultSrc: ["https: 'self'"],
  36. baseUri: ["'self'"],
  37. childSrc: ["*", "blob:"],
  38. connectSrc: ["*"],
  39. fontSrc: ["*", "'self'"],
  40. formAction: ["'self'"],
  41. frameAncestors: ["*", "*.standardnotes.org", "*.standardnotes.com"],
  42. frameSrc: ["*", "blob:"],
  43. imgSrc: ["'self'", "*", "data:"],
  44. manifestSrc: ["'self'"],
  45. mediaSrc: ["'self'"],
  46. objectSrc: ["'self'"],
  47. scriptSrc: ["'self'"],
  48. styleSrc: ["'self'"]
  49. }
  50. }
  51. }))
  52. /* eslint-enable */
  53. app.use(json({ limit: '50mb' }))
  54. app.use(raw({ limit: '50mb', type: 'application/octet-stream' }))
  55. app.use(urlencoded({ extended: true, limit: '50mb' }))
  56. app.use(
  57. cors({
  58. exposedHeaders: ['Content-Range', 'Accept-Ranges'],
  59. }),
  60. )
  61. app.use(
  62. robots({
  63. UserAgent: '*',
  64. Disallow: '/',
  65. }),
  66. )
  67. })
  68. const logger: winston.Logger = container.get(TYPES.Files_Logger)
  69. server.setErrorConfig((app) => {
  70. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  71. logger.error(error.stack)
  72. response.status(500).send({
  73. error: {
  74. message:
  75. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  76. },
  77. })
  78. })
  79. })
  80. const serverInstance = server.build()
  81. serverInstance.listen(env.get('PORT'))
  82. logger.info(`Server started on port ${process.env.PORT}`)
  83. })