kernel.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. const _ = require('lodash')
  2. const EventEmitter = require('eventemitter2').EventEmitter2
  3. /* global WIKI */
  4. module.exports = {
  5. async init() {
  6. WIKI.logger.info('=======================================')
  7. WIKI.logger.info(`= Wiki.js ${_.padEnd(WIKI.version + ' ', 29, '=')}`)
  8. WIKI.logger.info('=======================================')
  9. WIKI.logger.info('Initializing...')
  10. WIKI.models = require('./db').init()
  11. try {
  12. await WIKI.models.onReady
  13. await WIKI.configSvc.loadFromDb()
  14. await WIKI.configSvc.applyFlags()
  15. } catch (err) {
  16. WIKI.logger.error('Database Initialization Error: ' + err.message)
  17. if (WIKI.IS_DEBUG) {
  18. console.error(err)
  19. }
  20. process.exit(1)
  21. }
  22. this.bootMaster()
  23. },
  24. /**
  25. * Pre-Master Boot Sequence
  26. */
  27. async preBootMaster() {
  28. try {
  29. await this.initTelemetry()
  30. WIKI.cache = require('./cache').init()
  31. WIKI.scheduler = require('./scheduler').init()
  32. WIKI.servers = require('./servers')
  33. WIKI.sideloader = require('./sideloader').init()
  34. WIKI.events = new EventEmitter()
  35. await WIKI.models.subscribeToNotifications()
  36. } catch (err) {
  37. WIKI.logger.error(err)
  38. process.exit(1)
  39. }
  40. },
  41. /**
  42. * Boot Master Process
  43. */
  44. async bootMaster() {
  45. try {
  46. if (WIKI.config.setup) {
  47. WIKI.logger.info('Starting setup wizard...')
  48. require('../setup')()
  49. } else {
  50. await this.preBootMaster()
  51. await require('../master')()
  52. this.postBootMaster()
  53. }
  54. } catch (err) {
  55. WIKI.logger.error(err)
  56. process.exit(1)
  57. }
  58. },
  59. /**
  60. * Post-Master Boot Sequence
  61. */
  62. async postBootMaster() {
  63. await WIKI.models.analytics.refreshProvidersFromDisk()
  64. await WIKI.models.authentication.refreshStrategiesFromDisk()
  65. await WIKI.models.editors.refreshEditorsFromDisk()
  66. await WIKI.models.loggers.refreshLoggersFromDisk()
  67. await WIKI.models.renderers.refreshRenderersFromDisk()
  68. await WIKI.models.searchEngines.refreshSearchEnginesFromDisk()
  69. await WIKI.models.storage.refreshTargetsFromDisk()
  70. await WIKI.auth.activateStrategies()
  71. await WIKI.models.searchEngines.initEngine()
  72. await WIKI.models.storage.initTargets()
  73. WIKI.scheduler.start()
  74. },
  75. /**
  76. * Init Telemetry
  77. */
  78. async initTelemetry() {
  79. require('./telemetry').init()
  80. process.on('unhandledRejection', (err) => {
  81. WIKI.logger.warn(err)
  82. WIKI.telemetry.sendError(err)
  83. })
  84. process.on('uncaughtException', (err) => {
  85. WIKI.logger.warn(err)
  86. WIKI.telemetry.sendError(err)
  87. })
  88. },
  89. /**
  90. * Graceful shutdown
  91. */
  92. async shutdown () {
  93. if (WIKI.models) {
  94. await WIKI.models.unsubscribeToNotifications()
  95. await WIKI.models.knex.client.pool.destroy()
  96. await WIKI.models.knex.destroy()
  97. }
  98. if (WIKI.scheduler) {
  99. WIKI.scheduler.stop()
  100. }
  101. if (WIKI.servers) {
  102. await WIKI.servers.stopServers()
  103. }
  104. }
  105. }