Files
speckle-server/packages/server/modules/webhooks/index.ts
T
2024-10-14 12:00:47 +03:00

32 lines
1.1 KiB
TypeScript

import cron from 'node-cron'
import { SpeckleModule } from '@/modules/shared/helpers/typeHelper'
import { cleanOrphanedWebhookConfigs } from '@/modules/webhooks/services/cleanup'
import { activitiesLogger, moduleLogger } from '@/logging/logging'
import { scheduleExecutionFactory } from '@/modules/core/services/taskScheduler'
import { acquireTaskLockFactory } from '@/modules/core/repositories/scheduledTasks'
import { db } from '@/db/knex'
const scheduleWebhookCleanup = () => {
const scheduleExecution = scheduleExecutionFactory({
acquireTaskLock: acquireTaskLockFactory({ db })
})
const cronExpression = '0 4 * * 1'
return scheduleExecution(cronExpression, 'weeklyWebhookCleanup', async () => {
activitiesLogger.info('Starting weekly webhooks cleanup')
await cleanOrphanedWebhookConfigs()
activitiesLogger.info('Finished cleanup')
})
}
let scheduledTask: cron.ScheduledTask | null = null
export const init: SpeckleModule['init'] = () => {
moduleLogger.info('🎣 Init webhooks module')
scheduledTask = scheduleWebhookCleanup()
}
export const shutdown: SpeckleModule['shutdown'] = () => {
if (scheduledTask) scheduledTask.stop()
}