server.ts 3.1 KB

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