server.ts 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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.SyncingServer })
  5. sdk.start()
  6. import '../src/Infra/InversifyExpressUtils/AnnotatedFallbackController'
  7. import '../src/Infra/InversifyExpressUtils/AnnotatedHealthCheckController'
  8. import '../src/Infra/InversifyExpressUtils/AnnotatedItemsController'
  9. import '../src/Infra/InversifyExpressUtils/AnnotatedMessagesController'
  10. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultInvitesController'
  11. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultUsersController'
  12. import '../src/Infra/InversifyExpressUtils/AnnotatedSharedVaultsController'
  13. import helmet from 'helmet'
  14. import * as cors from 'cors'
  15. import { urlencoded, json, Request, Response, NextFunction } from 'express'
  16. import * as winston from 'winston'
  17. import { InversifyExpressServer } from 'inversify-express-utils'
  18. import TYPES from '../src/Bootstrap/Types'
  19. import { Env } from '../src/Bootstrap/Env'
  20. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  21. const container = new ContainerConfigLoader()
  22. void container.load().then((container) => {
  23. const env: Env = new Env()
  24. env.load()
  25. const server = new InversifyExpressServer(container)
  26. server.setConfig((app) => {
  27. app.use((_request: Request, response: Response, next: NextFunction) => {
  28. response.setHeader('X-SSJS-Version', container.get(TYPES.Sync_VERSION))
  29. next()
  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"],
  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(urlencoded({ extended: true, limit: '50mb', parameterLimit: 5000 }))
  55. app.use(cors())
  56. })
  57. const logger: winston.Logger = container.get(TYPES.Sync_Logger)
  58. server.setErrorConfig((app) => {
  59. app.use((error: Record<string, unknown>, _request: Request, response: Response, _next: NextFunction) => {
  60. logger.error(error.stack)
  61. response.status(500).send({
  62. error: {
  63. message:
  64. "Unfortunately, we couldn't handle your request. Please try again or contact our support if the error persists.",
  65. },
  66. })
  67. })
  68. })
  69. const serverInstance = server.build()
  70. serverInstance.listen(env.get('PORT'))
  71. logger.info(`Server started on port ${process.env.PORT}`)
  72. })