worker.ts 893 B

1234567891011121314151617181920212223242526272829303132
  1. import 'reflect-metadata'
  2. import { Logger } from 'winston'
  3. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  4. import TYPES from '../src/Bootstrap/Types'
  5. import { Env } from '../src/Bootstrap/Env'
  6. import { DomainEventSubscriberInterface } from '@standardnotes/domain-events'
  7. import * as dayjs from 'dayjs'
  8. import * as utc from 'dayjs/plugin/utc'
  9. const container = new ContainerConfigLoader()
  10. void container.load().then((container) => {
  11. dayjs.extend(utc)
  12. const env: Env = new Env()
  13. env.load()
  14. const logger: Logger = container.get(TYPES.Files_Logger)
  15. logger.info('Starting worker...')
  16. const subscriber = container.get<DomainEventSubscriberInterface>(TYPES.Files_DomainEventSubscriber)
  17. process.on('SIGTERM', () => {
  18. logger.info('SIGTERM received. Stopping worker...')
  19. subscriber.stop()
  20. logger.info('Worker stopped.')
  21. })
  22. subscriber.start()
  23. })