task.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. const LoggerKit = require('../kit/logger-kit')
  2. const log4js = require('log4js')
  3. const TimeKit = require('../kit/time-kit')
  4. class Task {
  5. context
  6. delayTime = 5 * 1000
  7. name
  8. logger
  9. fileLogger
  10. running = true
  11. constructor(taskName, context, initFun, onTickFun) {
  12. this.name = taskName
  13. this.init = initFun
  14. this.onTick = onTickFun
  15. this.context = context
  16. this.consoleLoggerInit()
  17. this.fileLoggerInit(this.name.concat('Task.log'))
  18. }
  19. setDelayTime(delayTime) {
  20. this.delayTime = delayTime
  21. }
  22. consoleLoggerInit() {
  23. this.logger = LoggerKit.getLogger(this.name)
  24. }
  25. fileLoggerInit(logFilePath) {
  26. const logFileCategoryName = this.name.concat('FileLog')
  27. const appender = { type: 'file', filename: logFilePath }
  28. const category = { appenders: [logFileCategoryName], level: log4js.levels.TRACE }
  29. LoggerKit.pushAppender(logFileCategoryName, appender)
  30. this.fileLogger = LoggerKit.pushCategory(logFileCategoryName, category)
  31. this.fileLogger.info('File logger has init.')
  32. }
  33. async Start() {
  34. const task = this
  35. this.logger.info(`Init context or others.`)
  36. await this.init()
  37. this.logger.info(`Dida dida dida, on tick, on tick...`)
  38. while (task.running) {
  39. try {
  40. await task.onTick()
  41. } catch (e) {
  42. task.fileLogger.error(e)
  43. }
  44. await TimeKit.sleep(task.delayTime)
  45. }
  46. }
  47. async Stop() {
  48. this.running = false
  49. }
  50. }
  51. module.exports = Task