wikijs-fork/server/core/auth.js

64 lines
1.8 KiB
JavaScript
Raw Normal View History

/* global WIKI */
2017-04-02 23:56:47 +00:00
2017-07-30 04:04:57 +00:00
const _ = require('lodash')
const passport = require('passport')
const fs = require('fs-extra')
const path = require('path')
const autoload = require('auto-load')
2017-04-02 23:56:47 +00:00
2017-08-03 03:47:11 +00:00
module.exports = {
strategies: {},
init() {
this.passport = passport
// Serialization user methods
2017-04-02 23:56:47 +00:00
2017-08-03 03:47:11 +00:00
passport.serializeUser(function (user, done) {
2018-01-10 01:41:53 +00:00
done(null, user.id)
2017-08-03 03:47:11 +00:00
})
2017-04-02 23:56:47 +00:00
2017-08-03 03:47:11 +00:00
passport.deserializeUser(function (id, done) {
WIKI.db.users.query().findById(id).then((user) => {
2017-08-03 03:47:11 +00:00
if (user) {
done(null, user)
} else {
done(new Error(WIKI.lang.t('auth:errors:usernotfound')), null)
2017-08-03 03:47:11 +00:00
}
return true
}).catch((err) => {
done(err, null)
})
2017-04-02 23:56:47 +00:00
})
2017-08-03 03:47:11 +00:00
// Load authentication strategies
2017-04-02 23:56:47 +00:00
const modules = _.values(autoload(path.join(WIKI.SERVERPATH, 'modules/authentication')))
_.forEach(modules, (strategy) => {
const strategyConfig = _.get(WIKI.config.auth.strategies, strategy.key, { isEnabled: false })
strategyConfig.callbackURL = `${WIKI.config.site.host}${WIKI.config.site.path}login/${strategy.key}/callback`
strategy.config = strategyConfig
if (strategyConfig.isEnabled) {
try {
strategy.init(passport, strategyConfig)
} catch (err) {
WIKI.logger.error(`Authentication Provider ${strategy.title}: [ FAILED ]`)
WIKI.logger.error(err)
}
}
fs.readFile(path.join(WIKI.ROOTPATH, `assets/svg/auth-icon-${strategy.key}.svg`), 'utf8').then(iconData => {
strategy.icon = iconData
}).catch(err => {
if (err.code === 'ENOENT') {
strategy.icon = '[missing icon]'
} else {
WIKI.logger.warn(err)
}
})
this.strategies[strategy.key] = strategy
WIKI.logger.info(`Authentication Provider ${strategy.title}: [ OK ]`)
2017-08-03 03:47:11 +00:00
})
2017-07-29 21:33:08 +00:00
return this
2017-08-03 03:47:11 +00:00
}
2017-04-02 23:56:47 +00:00
}