59 lines
1.4 KiB
JavaScript
59 lines
1.4 KiB
JavaScript
|
'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
|
||
|
}
|
||
|
}
|