123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- #!/usr/bin/env node
- // ===========================================
- // Wiki.js
- // 2.0
- // Licensed under AGPLv3
- // ===========================================
- const Promise = require('bluebird')
- const fs = Promise.promisifyAll(require('fs-extra'))
- const pm2 = Promise.promisifyAll(require('pm2'))
- const ora = require('ora')
- const path = require('path')
- const cluster = require('cluster')
- const _ = require('lodash')
- const chalk = require('chalk')
- const ROOTPATH = process.cwd()
- const init = {
- /**
- * Start in background mode
- */
- start () {
- let spinner = ora('Initializing...').start()
- return fs.emptyDirAsync(path.join(ROOTPATH, './logs')).then(() => {
- return pm2.connectAsync().then(() => {
- return pm2.startAsync({
- name: 'wiki',
- script: 'server',
- cwd: ROOTPATH,
- output: path.join(ROOTPATH, './logs/wiki-output.log'),
- error: path.join(ROOTPATH, './logs/wiki-error.log'),
- minUptime: 5000,
- maxRestarts: 5
- }).then(() => {
- spinner.succeed('Wiki.js has started successfully.')
- }).finally(() => {
- pm2.disconnect()
- })
- })
- }).catch(err => {
- spinner.fail(err)
- process.exit(1)
- })
- },
- /**
- * Stop Wiki.js process(es)
- */
- stop () {
- let spinner = ora('Shutting down Wiki.js...').start()
- return pm2.connectAsync().then(() => {
- return pm2.stopAsync('wiki').then(() => {
- spinner.succeed('Wiki.js has stopped successfully.')
- }).finally(() => {
- pm2.disconnect()
- })
- }).catch(err => {
- spinner.fail(err)
- process.exit(1)
- })
- },
- /**
- * Restart Wiki.js process(es)
- */
- restart: function () {
- return this.stop().delay(1000).then(() => {
- this.start()
- })
- },
- dev() {
- if (cluster.isMaster) {
- const webpack = require('webpack')
- const chokidar = require('chokidar')
- global.DEV = true
- global.WP_CONFIG = require('./dev/webpack/webpack.dev.js')
- global.WP = webpack(global.WP_CONFIG)
- global.WP_DEV = {
- devMiddleware: require('webpack-dev-middleware')(global.WP, {
- publicPath: global.WP_CONFIG.output.publicPath
- }),
- hotMiddleware: require('webpack-hot-middleware')(global.WP)
- }
- global.WP_DEV.devMiddleware.waitUntilValid(() => {
- console.info(chalk.yellow.bold('>>> Starting Wiki.js in DEVELOPER mode...'))
- require('./server')
- process.stdin.setEncoding('utf8')
- process.stdin.on('data', data => {
- if (_.trim(data) === 'rs') {
- console.warn(chalk.yellow.bold('--- >>>>>>>>>>>>>>>>>>>>>>>> ---'))
- console.warn(chalk.yellow.bold('--- Manual restart requested ---'))
- console.warn(chalk.yellow.bold('--- <<<<<<<<<<<<<<<<<<<<<<<< ---'))
- this.reload()
- }
- })
- const devWatcher = chokidar.watch([
- './server',
- '!./server/views/master.pug'
- ], {
- ignoreInitial: true,
- atomic: 400
- })
- devWatcher.on('ready', () => {
- devWatcher.on('all', () => {
- console.warn(chalk.yellow.bold('--- >>>>>>>>>>>>>>>>>>>>>>>>>>>> ---'))
- console.warn(chalk.yellow.bold('--- Changes detected: Restarting ---'))
- console.warn(chalk.yellow.bold('--- <<<<<<<<<<<<<<<<<<<<<<<<<<<< ---'))
- this.reload()
- })
- })
- })
- } else {
- require('./server')
- }
- },
- async reload() {
- console.warn(chalk.yellow('--- Closing DB connections...'))
- await global.WIKI.models.knex.destroy()
- console.warn(chalk.yellow('--- Closing Redis connections...'))
- await global.WIKI.redis.quit()
- await global.WIKI.redisSub.quit()
- console.warn(chalk.yellow('--- Closing Queue connections...'))
- await global.WIKI.queue.quit()
- console.warn(chalk.yellow('--- Closing Server connections...'))
- global.WIKI.server.destroy(() => {
- console.warn(chalk.yellow('--- Purging node modules cache...'))
- global.WIKI = {}
- Object.keys(require.cache).forEach(id => {
- if (/[/\\]server[/\\]/.test(id)) {
- delete require.cache[id]
- }
- })
- Object.keys(module.constructor._pathCache).forEach(cacheKey => {
- if (/[/\\]server[/\\]/.test(cacheKey)) {
- delete module.constructor._pathCache[cacheKey]
- }
- })
- console.warn(chalk.yellow('--- Unregistering process listeners...'))
- process.removeAllListeners('unhandledRejection')
- process.removeAllListeners('uncaughtException')
- require('./server')
- })
- }
- }
- require('yargs') // eslint-disable-line no-unused-expressions
- .usage('Usage: node $0 <cmd> [args]')
- .command({
- command: 'start',
- alias: ['boot', 'init'],
- desc: 'Start Wiki.js process',
- handler: argv => {
- init.start()
- }
- })
- .command({
- command: 'stop',
- alias: ['quit', 'exit'],
- desc: 'Stop Wiki.js process',
- handler: argv => {
- init.stop()
- }
- })
- .command({
- command: 'restart',
- alias: ['reload'],
- desc: 'Restart Wiki.js process',
- handler: argv => {
- init.restart()
- }
- })
- .command({
- command: 'dev',
- desc: 'Start in Developer Mode',
- handler: argv => {
- init.dev()
- }
- })
- .recommendCommands()
- .demandCommand(1, 'You must provide one of the accepted commands above.')
- .help()
- .version()
- .epilogue('Read the docs at https://docs.requarks.io/wiki')
- .argv
|