CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var nconf = require('nconf');
|
|
|
|
var url = require('url');
|
|
|
|
var winston = require('winston');
|
|
|
|
var path = require('path');
|
|
|
|
|
|
|
|
var pkg = require('../package.json');
|
|
|
|
var dirname = require('./cli/paths').baseDir;
|
|
|
|
|
|
|
|
function setupWinston() {
|
|
|
|
if (!winston.format) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var formats = [];
|
|
|
|
if (nconf.get('log-colorize') !== 'false') {
|
|
|
|
formats.push(winston.format.colorize());
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nconf.get('json-logging')) {
|
|
|
|
formats.push(winston.format.timestamp());
|
|
|
|
formats.push(winston.format.json());
|
|
|
|
} else {
|
|
|
|
const timestampFormat = winston.format((info) => {
|
|
|
|
var dateString = new Date().toISOString() + ' [' + nconf.get('port') + '/' + global.process.pid + ']';
|
|
|
|
info.level = dateString + ' - ' + info.level;
|
|
|
|
return info;
|
|
|
|
});
|
|
|
|
formats.push(timestampFormat());
|
|
|
|
formats.push(winston.format.splat());
|
|
|
|
formats.push(winston.format.simple());
|
|
|
|
}
|
|
|
|
|
|
|
|
winston.configure({
|
|
|
|
level: nconf.get('log-level') || (process.env.NODE_ENV === 'production' ? 'info' : 'verbose'),
|
|
|
|
format: winston.format.combine.apply(null, formats),
|
|
|
|
transports: [
|
|
|
|
new winston.transports.Console({
|
|
|
|
handleExceptions: true,
|
|
|
|
}),
|
|
|
|
],
|
CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadConfig(configFile) {
|
|
|
|
nconf.file({
|
|
|
|
file: configFile,
|
|
|
|
});
|
|
|
|
|
|
|
|
nconf.defaults({
|
|
|
|
base_dir: dirname,
|
|
|
|
themes_path: path.join(dirname, 'node_modules'),
|
|
|
|
upload_path: 'public/uploads',
|
|
|
|
views_dir: path.join(dirname, 'build/public/templates'),
|
|
|
|
version: pkg.version,
|
|
|
|
isCluster: false,
|
|
|
|
isPrimary: true,
|
|
|
|
jobsDisabled: false,
|
CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
});
|
|
|
|
|
|
|
|
// Explicitly cast as Bool, loader.js passes in isCluster as string 'true'/'false'
|
|
|
|
var castAsBool = ['isCluster', 'isPrimary', 'jobsDisabled'];
|
|
|
|
nconf.stores.env.readOnly = false;
|
|
|
|
castAsBool.forEach(function (prop) {
|
|
|
|
var value = nconf.get(prop);
|
|
|
|
if (value !== undefined) {
|
|
|
|
nconf.set(prop, typeof value === 'boolean' ? value : String(value).toLowerCase() === 'true');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
nconf.stores.env.readOnly = true;
|
|
|
|
nconf.set('runJobs', nconf.get('isPrimary') && !nconf.get('jobsDisabled'));
|
CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
|
|
|
|
// Ensure themes_path is a full filepath
|
|
|
|
nconf.set('themes_path', path.resolve(dirname, nconf.get('themes_path')));
|
|
|
|
nconf.set('core_templates_path', path.join(dirname, 'src/views'));
|
|
|
|
nconf.set('base_templates_path', path.join(nconf.get('themes_path'), 'nodebb-theme-persona/templates'));
|
|
|
|
|
|
|
|
nconf.set('upload_path', path.resolve(nconf.get('base_dir'), nconf.get('upload_path')));
|
|
|
|
nconf.set('upload_url', '/assets/uploads');
|
CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
|
|
|
|
|
|
|
|
// nconf defaults, if not set in config
|
|
|
|
if (!nconf.get('sessionKey')) {
|
|
|
|
nconf.set('sessionKey', 'express.sid');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nconf.get('url')) {
|
|
|
|
nconf.set('url_parsed', url.parse(nconf.get('url')));
|
|
|
|
// Parse out the relative_url and other goodies from the configured URL
|
|
|
|
const urlObject = url.parse(nconf.get('url'));
|
|
|
|
const relativePath = urlObject.pathname !== '/' ? urlObject.pathname.replace(/\/+$/, '') : '';
|
|
|
|
nconf.set('base_url', urlObject.protocol + '//' + urlObject.host);
|
|
|
|
nconf.set('secure', urlObject.protocol === 'https:');
|
|
|
|
nconf.set('use_port', !!urlObject.port);
|
|
|
|
nconf.set('relative_path', relativePath);
|
|
|
|
nconf.set('port', nconf.get('PORT') || nconf.get('port') || urlObject.port || (nconf.get('PORT_ENV_VAR') ? nconf.get(nconf.get('PORT_ENV_VAR')) : false) || 4567);
|
|
|
|
}
|
CLI refactor with commander (#6058)
* CLI refactor with commander
- Modularized the functionality
- All functionality done directly from `./nodebb` now
(still available from `app` for backwards compatibility)
- Moved all CLI code from `./nodebb` to `src/cli`
- Fixed `nodebb.bat` to work from any location, like `./nodebb`, and
also hides command output
- Overwrite some commander methods to add CLI color support
- Added `./nodebb info` for quick info including git hash, NodeBB
version, node version, and some database info
- Refactored `./nodebb reset` to allow multiple resets at once
- Changed `./nodebb restart` to essentially stop and start, as Windows
doesn't support signals
- Added `-l, --log` option which works on `./nodebb start` and `./nodebb
restart` to show logging, like `./nodebb slog`
- Expanded `-d, --dev` option which works on them as well, like
`./nodebb dev`
- Improvements to self-help. `./nodebb build -h` will output all
possible targets
- `./nodebb reset` explains usage better
* Fix some style inconsistencies
* Fix prestart being required before modules installed
* Fix travis failures
* Fix `help` command to output help for subcommands
* Pick steps of the upgrade process to run
* Fix formatting for upgrade help
* Fix web installer
7 years ago
|
|
|
}
|
|
|
|
|
|
|
|
function versionCheck() {
|
|
|
|
var version = process.version.slice(1);
|
|
|
|
var range = pkg.engines.node;
|
|
|
|
var semver = require('semver');
|
|
|
|
var compatible = semver.satisfies(version, range);
|
|
|
|
|
|
|
|
if (!compatible) {
|
|
|
|
winston.warn('Your version of Node.js is too outdated for NodeBB. Please update your version of Node.js.');
|
|
|
|
winston.warn('Recommended ' + range.green + ', '.reset + version.yellow + ' provided\n'.reset);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.setupWinston = setupWinston;
|
|
|
|
exports.loadConfig = loadConfig;
|
|
|
|
exports.versionCheck = versionCheck;
|