2021-06-16 14:42:06 +01:00
|
|
|
const Nconf = require('nconf');
|
|
|
|
const path = require('path');
|
|
|
|
const _debug = require('@tryghost/debug')._base;
|
|
|
|
const debug = _debug('ghost:config');
|
|
|
|
const localUtils = require('./utils');
|
2021-06-16 15:05:51 +01:00
|
|
|
const helpers = require('./helpers');
|
2021-06-17 12:15:44 +01:00
|
|
|
const urlHelpers = require('@tryghost/config-url-helpers');
|
2021-06-16 14:42:06 +01:00
|
|
|
const env = process.env.NODE_ENV || 'development';
|
|
|
|
|
2021-06-17 12:15:44 +01:00
|
|
|
/**
|
|
|
|
* @param {object} options
|
2021-06-18 20:34:14 +01:00
|
|
|
* @returns {Nconf.Provider & urlHelpers.BoundHelpers & helpers.ConfigHelpers}
|
2021-06-17 12:15:44 +01:00
|
|
|
*/
|
2021-06-16 14:42:06 +01:00
|
|
|
function loadNconf(options) {
|
|
|
|
debug('config start');
|
|
|
|
options = options || {};
|
|
|
|
|
|
|
|
const baseConfigPath = options.baseConfigPath || __dirname;
|
|
|
|
const customConfigPath = options.customConfigPath || process.cwd();
|
|
|
|
const nconf = new Nconf.Provider();
|
|
|
|
|
|
|
|
// ## Load Config
|
|
|
|
|
|
|
|
// no channel can override the overrides
|
|
|
|
nconf.file('overrides', path.join(baseConfigPath, 'overrides.json'));
|
|
|
|
|
|
|
|
// command line arguments take precedence, then environment variables
|
|
|
|
nconf.argv();
|
|
|
|
nconf.env({separator: '__', parseValues: true});
|
|
|
|
|
|
|
|
// Now load various config json files
|
|
|
|
nconf.file('custom-env', path.join(customConfigPath, 'config.' + env + '.json'));
|
|
|
|
if (env !== 'testing') {
|
|
|
|
nconf.file('local-env', path.join(customConfigPath, 'config.local.json'));
|
|
|
|
}
|
|
|
|
nconf.file('default-env', path.join(baseConfigPath, 'env', 'config.' + env + '.json'));
|
|
|
|
|
|
|
|
// Finally, we load defaults, if nothing else has a value this will
|
|
|
|
nconf.file('defaults', path.join(baseConfigPath, 'defaults.json'));
|
|
|
|
|
|
|
|
// ## Config Methods
|
|
|
|
|
|
|
|
// Expose dynamic utility methods
|
2021-06-17 12:15:44 +01:00
|
|
|
urlHelpers.bindAll(nconf);
|
2021-10-22 15:22:43 +01:00
|
|
|
helpers.bindAll(nconf);
|
2021-06-16 14:42:06 +01:00
|
|
|
|
|
|
|
// ## Sanitization
|
|
|
|
|
|
|
|
// transform all relative paths to absolute paths
|
2021-06-18 21:19:16 +01:00
|
|
|
localUtils.makePathsAbsolute(nconf, nconf.get('paths'), 'paths');
|
2021-06-16 14:42:06 +01:00
|
|
|
|
|
|
|
// transform sqlite filename path for Ghost-CLI
|
2021-06-18 21:19:16 +01:00
|
|
|
localUtils.sanitizeDatabaseProperties(nconf);
|
2021-06-16 14:42:06 +01:00
|
|
|
|
|
|
|
// Check if the URL in config has a protocol
|
2021-06-18 21:19:16 +01:00
|
|
|
localUtils.checkUrlProtocol(nconf.get('url'));
|
2021-06-16 14:42:06 +01:00
|
|
|
|
|
|
|
// Ensure that the content path exists
|
2021-06-18 21:19:16 +01:00
|
|
|
localUtils.doesContentPathExist(nconf.get('paths:contentPath'));
|
2021-06-16 14:42:06 +01:00
|
|
|
|
|
|
|
// ## Other Stuff!
|
|
|
|
|
|
|
|
// Manually set values
|
|
|
|
nconf.set('env', env);
|
|
|
|
|
|
|
|
// Wrap this in a check, because else nconf.get() is executed unnecessarily
|
|
|
|
// To output this, use DEBUG=ghost:*,ghost-config
|
|
|
|
if (_debug.enabled('ghost-config')) {
|
|
|
|
debug(nconf.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
debug('config end');
|
|
|
|
return nconf;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports.loadNconf = loadNconf;
|