'use strict' /* global winston */ const fs = require('fs') const yaml = require('js-yaml') const _ = require('lodash') /** * Load Application Configuration * * @param {Object} confPaths Path to the configuration files * @return {Object} Application Configuration */ module.exports = (confPaths) => { confPaths = _.defaults(confPaths, { config: './config.yml', data: './app/data.yml' }) let appconfig = {} let appdata = {} try { appconfig = yaml.safeLoad(fs.readFileSync(confPaths.config, 'utf8')) appdata = yaml.safeLoad(fs.readFileSync(confPaths.data, 'utf8')) } catch (ex) { winston.error(ex) process.exit(1) } // Merge with defaults appconfig = _.defaultsDeep(appconfig, appdata.defaults.config) // List authentication strategies if (appdata.capabilities.manyAuthProviders) { appconfig.authStrategies = { list: _.filter(appconfig.auth, ['enabled', true]), socialEnabled: (_.chain(appconfig.auth).omit('local').reject({ enabled: false }).value().length > 0) } if (appconfig.authStrategies.list.length < 1) { winston.error(new Error('You must enable at least 1 authentication strategy!')) process.exit(1) } } else { appconfig.authStrategies = { list: { local: { enabled: true } }, socialEnabled: false } } return { config: appconfig, data: appdata } }