backup.ts 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import 'reflect-metadata'
  2. import { Logger } from 'winston'
  3. import * as dayjs from 'dayjs'
  4. import * as utc from 'dayjs/plugin/utc'
  5. import { ContainerConfigLoader } from '../src/Bootstrap/Container'
  6. import TYPES from '../src/Bootstrap/Types'
  7. import { Env } from '../src/Bootstrap/Env'
  8. import { TriggerEmailBackupForAllUsers } from '../src/Domain/UseCase/TriggerEmailBackupForAllUsers/TriggerEmailBackupForAllUsers'
  9. const inputArgs = process.argv.slice(2)
  10. const backupFrequency = inputArgs[0]
  11. const requestBackups = async (triggerEmailBackupForAllUsers: TriggerEmailBackupForAllUsers): Promise<void> => {
  12. await triggerEmailBackupForAllUsers.execute({ backupFrequency })
  13. }
  14. const container = new ContainerConfigLoader('worker')
  15. void container.load().then((container) => {
  16. dayjs.extend(utc)
  17. const env: Env = new Env()
  18. env.load()
  19. const logger: Logger = container.get(TYPES.Auth_Logger)
  20. logger.info(`Starting ${backupFrequency} email backup requesting...`)
  21. const triggerEmailBackupForAllUsers: TriggerEmailBackupForAllUsers = container.get(
  22. TYPES.Auth_TriggerEmailBackupForAllUsers,
  23. )
  24. Promise.resolve(requestBackups(triggerEmailBackupForAllUsers))
  25. .then(() => {
  26. logger.info(`${backupFrequency} email backup requesting complete`)
  27. process.exit(0)
  28. })
  29. .catch((error) => {
  30. logger.error(`Could not finish ${backupFrequency} email backup requesting: ${error.message}`)
  31. process.exit(1)
  32. })
  33. })