1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- const passport = require('passport')
- const passportJWT = require('passport-jwt')
- const fs = require('fs-extra')
- const _ = require('lodash')
- const path = require('path')
- const securityHelper = require('../helpers/security')
- /* global WIKI */
- module.exports = {
- strategies: {},
- init() {
- this.passport = passport
- // Serialization user methods
- passport.serializeUser(function (user, done) {
- done(null, user.id)
- })
- passport.deserializeUser(function (id, done) {
- WIKI.models.users.query().findById(id).then((user) => {
- if (user) {
- done(null, user)
- } else {
- done(new Error(WIKI.lang.t('auth:errors:usernotfound')), null)
- }
- return true
- }).catch((err) => {
- done(err, null)
- })
- })
- return this
- },
- async activateStrategies() {
- try {
- // Unload any active strategies
- WIKI.auth.strategies = {}
- const currentStrategies = _.keys(passport._strategies)
- _.pull(currentStrategies, 'session')
- _.forEach(currentStrategies, stg => { passport.unuse(stg) })
- // Load JWT
- passport.use('jwt', new passportJWT.Strategy({
- jwtFromRequest: securityHelper.extractJWT,
- secretOrKey: WIKI.config.sessionSecret,
- audience: 'urn:wiki.js', // TODO: use value from admin
- issuer: 'urn:wiki.js'
- }, (jwtPayload, cb) => {
- cb(null, jwtPayload)
- }))
- // Load enabled strategies
- const enabledStrategies = await WIKI.models.authentication.getStrategies()
- for (let idx in enabledStrategies) {
- const stg = enabledStrategies[idx]
- if (!stg.isEnabled) { continue }
- const strategy = require(`../modules/authentication/${stg.key}/authentication.js`)
- stg.config.callbackURL = `${WIKI.config.host}/login/${stg.key}/callback` // TODO: config.host
- strategy.init(passport, stg.config)
- 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)
- }
- })
- WIKI.auth.strategies[stg.key] = strategy
- WIKI.logger.info(`Authentication Strategy ${stg.title}: [ OK ]`)
- }
- } catch (err) {
- WIKI.logger.error(`Authentication Strategy: [ FAILED ]`)
- WIKI.logger.error(err)
- }
- }
- }
|