2018-12-20 14:31:11 +01:00
|
|
|
import { logger } from '../../helpers/logger'
|
|
|
|
|
2018-01-11 09:35:50 +01:00
|
|
|
export abstract class AbstractScheduler {
|
|
|
|
|
2018-06-14 18:06:56 +02:00
|
|
|
protected abstract schedulerIntervalMs: number
|
|
|
|
|
2018-01-11 09:35:50 +01:00
|
|
|
private interval: NodeJS.Timer
|
2018-12-20 14:31:11 +01:00
|
|
|
private isRunning = false
|
2018-01-11 09:35:50 +01:00
|
|
|
|
|
|
|
enable () {
|
2018-06-14 18:06:56 +02:00
|
|
|
if (!this.schedulerIntervalMs) throw new Error('Interval is not correctly set.')
|
|
|
|
|
|
|
|
this.interval = setInterval(() => this.execute(), this.schedulerIntervalMs)
|
2018-01-11 09:35:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
disable () {
|
|
|
|
clearInterval(this.interval)
|
|
|
|
}
|
|
|
|
|
2018-12-20 14:31:11 +01:00
|
|
|
async execute () {
|
|
|
|
if (this.isRunning === true) return
|
|
|
|
this.isRunning = true
|
|
|
|
|
|
|
|
try {
|
|
|
|
await this.internalExecute()
|
|
|
|
} catch (err) {
|
|
|
|
logger.error('Cannot execute %s scheduler.', this.constructor.name, { err })
|
|
|
|
} finally {
|
|
|
|
this.isRunning = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected abstract internalExecute (): Promise<any>
|
2018-01-11 09:35:50 +01:00
|
|
|
}
|