wiki.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #!/usr/bin/env node
  2. 'use strict'
  3. const Promise = require('bluebird')
  4. const fs = Promise.promisifyAll(require('fs-extra'))
  5. const ora = require('ora')
  6. const pm2 = Promise.promisifyAll(require('pm2'))
  7. const cmdr = require('commander')
  8. const path = require('path')
  9. const packageObj = fs.readJsonSync('package.json')
  10. cmdr.version(packageObj.version)
  11. cmdr.command('start')
  12. .description('Start Wiki.js process')
  13. .action(() => {
  14. let spinner = ora('Initializing...').start()
  15. fs.emptyDirAsync(path.join(__dirname, './logs')).then(() => {
  16. return pm2.connectAsync().then(() => {
  17. return pm2.startAsync({
  18. name: 'wiki',
  19. script: 'server.js',
  20. cwd: __dirname,
  21. output: path.join(__dirname, './logs/wiki-output.log'),
  22. error: path.join(__dirname, './logs/wiki-error.log'),
  23. minUptime: 5000,
  24. maxRestarts: 5
  25. }).then(() => {
  26. spinner.succeed('Wiki.js has started successfully.')
  27. }).finally(() => {
  28. pm2.disconnect()
  29. })
  30. })
  31. }).catch(err => {
  32. spinner.fail(err)
  33. process.exit(1)
  34. })
  35. })
  36. cmdr.command('stop')
  37. .description('Stop Wiki.js process')
  38. .action(() => {
  39. let spinner = ora('Shutting down Wiki.js...').start()
  40. pm2.connectAsync().then(() => {
  41. return pm2.stopAsync('wiki').then(() => {
  42. spinner.succeed('Wiki.js has stopped successfully.')
  43. }).finally(() => {
  44. pm2.disconnect()
  45. })
  46. }).catch(err => {
  47. spinner.fail(err)
  48. process.exit(1)
  49. })
  50. })
  51. cmdr.parse(process.argv)
  52. if (!process.argv.slice(2).length) {
  53. cmdr.help()
  54. }