kernel.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. const _ = require('lodash')
  2. const EventEmitter = require('eventemitter2').EventEmitter2
  3. let isShuttingDown = false
  4. /* global WIKI */
  5. module.exports = {
  6. async init() {
  7. WIKI.logger.info('=======================================')
  8. WIKI.logger.info(`= Wiki.js ${_.padEnd(WIKI.version + ' ', 29, '=')}`)
  9. WIKI.logger.info('=======================================')
  10. WIKI.logger.info('Initializing...')
  11. WIKI.models = require('./db').init()
  12. try {
  13. await WIKI.models.onReady
  14. await WIKI.configSvc.loadFromDb()
  15. await WIKI.configSvc.applyFlags()
  16. } catch (err) {
  17. WIKI.logger.error('Database Initialization Error: ' + err.message)
  18. if (WIKI.IS_DEBUG) {
  19. WIKI.logger.error(err)
  20. }
  21. process.exit(1)
  22. }
  23. this.bootWeb()
  24. },
  25. /**
  26. * Pre-Web Boot Sequence
  27. */
  28. async preBootWeb() {
  29. try {
  30. WIKI.cache = require('./cache').init()
  31. WIKI.scheduler = await require('./scheduler').init()
  32. WIKI.servers = require('./servers')
  33. WIKI.events = {
  34. inbound: new EventEmitter(),
  35. outbound: new EventEmitter()
  36. }
  37. WIKI.extensions = require('./extensions')
  38. WIKI.asar = require('./asar')
  39. } catch (err) {
  40. WIKI.logger.error(err)
  41. process.exit(1)
  42. }
  43. },
  44. /**
  45. * Boot Web Process
  46. */
  47. async bootWeb() {
  48. try {
  49. await this.preBootWeb()
  50. await require('../web')()
  51. this.postBootWeb()
  52. } catch (err) {
  53. WIKI.logger.error(err)
  54. process.exit(1)
  55. }
  56. },
  57. /**
  58. * Post-Web Boot Sequence
  59. */
  60. async postBootWeb() {
  61. await WIKI.models.analytics.refreshProvidersFromDisk()
  62. await WIKI.models.authentication.refreshStrategiesFromDisk()
  63. await WIKI.models.commentProviders.refreshProvidersFromDisk()
  64. await WIKI.models.renderers.refreshRenderersFromDisk()
  65. await WIKI.models.storage.refreshTargetsFromDisk()
  66. await WIKI.extensions.init()
  67. await WIKI.auth.activateStrategies()
  68. await WIKI.models.commentProviders.initProvider()
  69. await WIKI.models.sites.reloadCache()
  70. await WIKI.models.storage.initTargets()
  71. WIKI.scheduler.start()
  72. await WIKI.models.subscribeToNotifications()
  73. },
  74. /**
  75. * Graceful shutdown
  76. */
  77. async shutdown (devMode = false) {
  78. if (isShuttingDown) { return }
  79. isShuttingDown = true
  80. if (WIKI.servers) {
  81. await WIKI.servers.stopServers()
  82. }
  83. if (WIKI.scheduler) {
  84. await WIKI.scheduler.stop()
  85. }
  86. if (WIKI.models) {
  87. await WIKI.models.unsubscribeToNotifications()
  88. if (WIKI.models.knex) {
  89. await WIKI.models.knex.destroy()
  90. }
  91. }
  92. if (WIKI.asar) {
  93. await WIKI.asar.unload()
  94. }
  95. if (!devMode) {
  96. WIKI.logger.info('Terminating process...')
  97. process.exit(0)
  98. }
  99. }
  100. }