2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#!/usr/bin/env node
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-04-25 12:20:29 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									var colors = require('colors'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										cproc = require('child_process'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										argv = require('minimist')(process.argv.slice(2)),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fs = require('fs'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										path = require('path'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										request = require('request'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										semver = require('semver'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										prompt = require('prompt'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										async = require('async');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} catch (e) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if (e.code === 'MODULE_NOT_FOUND') {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('NodeBB could not be started because it\'s dependencies have not been installed.\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('Please ensure that you have executed "npm install --production" prior to running NodeBB.\n\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('For more information, please see: https://docs.nodebb.org/en/latest/installing/os.html\n\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('Could not start: ' + e.code + '\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.exit(1);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var getRunningPid = function(callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fs.readFile(__dirname + '/pidfile', {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											encoding: 'utf-8'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}, function(err, pid) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.kill(parseInt(pid, 10), 0);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												callback(null, parseInt(pid, 10));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} catch(e) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												callback(e);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									getCurrentVersion = function(callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fs.readFile(path.join(__dirname, 'package.json'), { encoding: 'utf-8' }, function(err, pkg) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												pkg = JSON.parse(pkg);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback(null, pkg.version);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} catch(err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									fork = function (args) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										cproc.fork('app.js', args, {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											cwd: __dirname,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											silent: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									getInstalledPlugins = function(callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										async.parallel({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											files: async.apply(fs.readdir, path.join(__dirname, 'node_modules')),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											deps: async.apply(fs.readFile, path.join(__dirname, 'package.json'), { encoding: 'utf-8' })
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}, function(err, payload) {
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											var isNbbModule = /^nodebb-(?:plugin|theme|widget|rewards)-[\w\-]+$/,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												moduleName, isGitRepo;
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											payload.files = payload.files.filter(function(file) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return isNbbModule.test(file);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											});
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											try {
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												payload.deps = JSON.parse(payload.deps).dependencies;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												payload.bundled = [];
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												payload.installed = [];
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} catch (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for (moduleName in payload.deps) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if (isNbbModule.test(moduleName)) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													payload.bundled.push(moduleName);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											// Whittle down deps to send back only extraneously installed plugins/themes/etc
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											payload.files.forEach(function(moduleName) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													fs.accessSync(path.join(__dirname, 'node_modules/' + moduleName, '.git'));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													isGitRepo = true;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} catch(e) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													isGitRepo = false;
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													payload.files.indexOf(moduleName) !== -1	// found in `node_modules/`
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													&& payload.bundled.indexOf(moduleName) === -1	// not found in `package.json`
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													&& !fs.lstatSync(path.join(__dirname, 'node_modules/' + moduleName)).isSymbolicLink()	// is not a symlink
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													&& !isGitRepo	// .git/ does not exist, so it is not a git repository
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													payload.installed.push(moduleName);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											});
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-11 11:12:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											getModuleVersions(payload.installed, callback);
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									getModuleVersions = function(modules, callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var versionHash = {};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										async.eachLimit(modules, 50, function(module, next) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											fs.readFile(path.join(__dirname, 'node_modules/' + module + '/package.json'), { encoding: 'utf-8' }, function(err, pkg) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													pkg = JSON.parse(pkg);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													versionHash[module] = pkg.version;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													next();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} catch (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													next(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}, function(err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											callback(err, versionHash);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									checkPlugins = function(standalone, callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if (standalone) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											process.stdout.write('Checking installed plugins and themes for updates... ');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										async.waterfall([
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											async.apply(async.parallel, {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												plugins: async.apply(getInstalledPlugins),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												version: async.apply(getCurrentVersion)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											function(payload, next) {
							 
						 
					
						
							
								
									
										
										
										
											2016-04-13 10:43:29 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												var toCheck = Object.keys(payload.plugins);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if (!toCheck.length) {
							 
						 
					
						
							
								
									
										
										
										
											2016-03-16 11:36:28 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													process.stdout.write('OK'.green + '\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2016-03-16 10:45:41 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													return next(null, []);	// no extraneous plugins installed
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												request({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													method: 'GET',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													url: 'https://packages.nodebb.org/api/v1/suggest?version=' + payload.version + '&package[]=' + toCheck.join('&package[]='),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													json: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}, function(err, res, body) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														process.stdout.write('error'.red + '\n'.reset);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														return next(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													process.stdout.write('OK'.green + '\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													if (!Array.isArray(body) && toCheck.length === 1) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														body = [body];
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													var current, suggested,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														upgradable = body.map(function(suggestObj) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															current = payload.plugins[suggestObj.package];
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															suggested = suggestObj.version;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															if (suggestObj.code === 'match-found' && semver.gt(suggested, current)) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																return {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																	name: suggestObj.package,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																	current: current,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																	suggested: suggested
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															} else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
																return null;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														}).filter(Boolean);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													next(null, upgradable);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										], callback);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									upgradePlugins = function(callback) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var standalone = false;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if (typeof callback !== 'function') {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											callback = function() {};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											standalone = true;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										checkPlugins(standalone, function(err, found) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\Warning'.yellow + ': An unexpected error occured when attempting to verify plugin upgradability\n'.reset);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (found && found.length) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\nA total of ' + new String(found.length).bold + ' package(s) can be upgraded:\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												found.forEach(function(suggestObj) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													process.stdout.write('  * '.yellow + suggestObj.name.reset + ' (' + suggestObj.current.yellow + ' -> '.reset + suggestObj.suggested.green + ')\n'.reset);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if (standalone) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													process.stdout.write('\nAll packages up-to-date!'.green + '\n'.reset);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return callback();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											prompt.message = '';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											prompt.delimiter = '';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											prompt.start();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											prompt.get({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												name: 'upgrade',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												description: 'Proceed with upgrade (y|n)?'.reset,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												type: 'string'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}, function(err, result) {
							 
						 
					
						
							
								
									
										
										
										
											2016-04-15 16:07:56 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if (['y', 'Y', 'yes', 'YES'].indexOf(result.upgrade) !== -1) {
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													process.stdout.write('\nUpgrading packages...');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													var args = ['npm', 'i'];
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													found.forEach(function(suggestObj) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														args.push(suggestObj.name + '@' + suggestObj.suggested);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													require('child_process').execFile('/usr/bin/env', args, { stdio: 'ignore' }, function(err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if (!err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															process.stdout.write(' OK\n'.green);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														callback(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													process.stdout.write('\nPackage upgrades skipped'.yellow + '. Check for upgrades at any time by running "'.reset + './nodebb upgrade-plugins'.green + '".\n'.reset);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													callback();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									};
							 
						 
					
						
							
								
									
										
										
										
											2015-11-03 11:50:14 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								switch(process.argv[2]) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'status':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										getRunningPid(function(err, pid) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (!err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\nNodeBB Running '.bold + '(pid '.cyan + pid.toString().cyan + ')\n'.cyan);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\t"' + './nodebb stop'.yellow + '" to stop the NodeBB server\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\t"' + './nodebb log'.yellow + '" to view server output\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\t"' + './nodebb restart'.yellow + '" to restart NodeBB\n\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\nNodeBB is not running\n'.bold);
							 
						 
					
						
							
								
									
										
										
										
											2015-07-08 18:52:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('\t"' + './nodebb start'.yellow + '" to launch the NodeBB server\n\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'start':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\nStarting NodeBB\n'.bold);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('  "' + './nodebb stop'.yellow + '" to stop the NodeBB server\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('  "' + './nodebb log'.yellow + '" to view server output\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-07-08 18:52:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										process.stdout.write('  "' + './nodebb restart'.yellow + '" to restart NodeBB\n\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Spawn a new NodeBB process
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										cproc.fork(__dirname + '/loader.js', {
							 
						 
					
						
							
								
									
										
										
										
											2015-06-30 22:21:01 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											env: process.env
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'stop':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										getRunningPid(function(err, pid) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (!err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.kill(pid, 'SIGTERM');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('Stopping NodeBB. Goodbye!\n')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('NodeBB is already stopped.\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'restart':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										getRunningPid(function(err, pid) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (!err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.kill(pid, 'SIGHUP');
							 
						 
					
						
							
								
									
										
										
										
											2016-02-23 13:22:55 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('\nRestarting NodeBB\n'.bold);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
									
										
										
										
											2016-02-23 13:22:55 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('NodeBB could not be restarted, as a running instance could not be found.\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'reload':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										getRunningPid(function(err, pid) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (!err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.kill(pid, 'SIGUSR2');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
									
										
										
										
											2016-02-23 13:22:55 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('NodeBB could not be reloaded, as a running instance could not be found.\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'dev':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.env.NODE_ENV = 'development';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										cproc.fork(__dirname + '/loader.js', ['--no-daemon', '--no-silent'], {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											env: process.env
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case 'log':
							 
						 
					
						
							
								
									
										
										
										
											2015-07-08 18:52:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										process.stdout.write('\nType '.red + 'Ctrl-C '.bold + 'to exit'.red);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\n\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										cproc.spawn('tail', ['-F', './logs/output.log'], {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											cwd: __dirname,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											stdio: 'inherit'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'setup':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										cproc.fork('app.js', ['--setup'], {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											cwd: __dirname,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											silent: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case 'reset':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var args = process.argv.slice(0);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										args.unshift('--reset');
							 
						 
					
						
							
								
									
										
										
										
											2015-11-03 11:50:14 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										fork(args);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-09-16 19:25:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case 'activate':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var args = process.argv.slice(0);
							 
						 
					
						
							
								
									
										
										
										
											2015-11-03 11:50:14 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										args.unshift('--activate');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fork(args);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
									
										
										
										
											2015-09-16 19:25:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-11-03 11:50:14 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case 'plugins':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										var args = process.argv.slice(0);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										args.unshift('--plugins');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fork(args);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
									
										
										
										
											2015-09-16 19:25:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case 'upgrade-plugins':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										upgradePlugins();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case 'upgrade':
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										async.series([
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											function(next) {
							 
						 
					
						
							
								
									
										
										
										
											2015-08-18 16:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('1. '.bold + 'Bringing base dependencies up to date... '.yellow);
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												require('child_process').execFile('/usr/bin/env', ['npm', 'i', '--production'], { stdio: 'ignore' }, next);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											function(next) {
							 
						 
					
						
							
								
									
										
										
										
											2015-08-18 16:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('OK\n'.green);
							 
						 
					
						
							
								
									
										
										
										
											2016-03-09 13:29:37 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('2. '.bold + 'Checking installed plugins for updates... '.yellow);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												upgradePlugins(next);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											function(next) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('3. '.bold + 'Updating NodeBB data store schema...\n'.yellow);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												var upgradeProc = cproc.fork('app.js', ['--upgrade'], {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													cwd: __dirname,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													silent: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												upgradeProc.on('close', next)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										], function(err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('\nError'.red + ': ' + err.message + '\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} else {
							 
						 
					
						
							
								
									
										
										
										
											2015-10-27 05:25:14 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												var message = 'NodeBB Upgrade Complete!';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												// some consoles will return undefined/zero columns, so just use 2 spaces in upgrade script if we can't get our column count
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												var columns = process.stdout.columns;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												var spaces = columns ? new Array(Math.floor(columns / 2) - (message.length / 2) + 1).join(' ') : "  ";
							 
						 
					
						
							
								
									
										
										
										
											2015-08-18 16:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												process.stdout.write('OK\n'.green);
							 
						 
					
						
							
								
									
										
										
										
											2015-07-08 18:47:17 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												process.stdout.write('\n' + spaces + message.green.bold + '\n\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 21:08:05 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									default:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\nWelcome to NodeBB\n\n'.bold);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('Usage: ./nodebb {start|stop|reload|restart|log|setup|reset|upgrade|dev}\n\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'start'.yellow + '\tStart the NodeBB server\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'stop'.yellow + '\tStops the NodeBB server\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'reload'.yellow + '\tRestarts NodeBB\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'restart'.yellow + '\tRestarts NodeBB\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'log'.yellow + '\tOpens the logging interface (useful for debugging)\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'setup'.yellow + '\tRuns the NodeBB setup script\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'reset'.yellow + '\tDisables all plugins, restores the default theme.\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-11-03 11:50:14 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'activate'.yellow + '\tActivate a plugin on start up.\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'plugins'.yellow + '\tList all plugins that have been installed.\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'upgrade'.yellow + '\tRun NodeBB upgrade scripts, ensure packages are up-to-date\n');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										process.stdout.write('\t' + 'dev'.yellow + '\tStart NodeBB in interactive development mode\n');
							 
						 
					
						
							
								
									
										
										
										
											2015-07-08 18:52:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										process.stdout.write('\n'.reset);
							 
						 
					
						
							
								
									
										
										
										
											2015-05-25 16:06:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										break;
							 
						 
					
						
							
								
									
										
										
										
											2016-01-10 01:03:26 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}