kernel.js 2.6 KB

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