task.js 1.5 KB

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