123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /* global WIKI */
- const _ = require('lodash')
- const passport = require('passport')
- const fs = require('fs-extra')
- const path = require('path')
- const autoload = require('auto-load')
- 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.db.User.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)
- })
- })
- // Load authentication strategies
- 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 ]`)
- })
- // Create Guest account for first-time
- WIKI.db.User.findOne({
- where: {
- provider: 'local',
- email: 'guest@example.com'
- }
- }).then((c) => {
- if (c < 1) {
- return WIKI.db.User.create({
- provider: 'local',
- email: 'guest@example.com',
- name: 'Guest',
- password: '',
- role: 'guest'
- }).then(() => {
- WIKI.logger.info('[AUTH] Guest account created successfully!')
- return true
- }).catch((err) => {
- WIKI.logger.error('[AUTH] An error occured while creating guest account:')
- WIKI.logger.error(err)
- return err
- })
- }
- })
- // .then(() => {
- // if (process.env.WIKI_JS_HEROKU) {
- // return WIKI.db.User.findOne({ provider: 'local', email: process.env.WIKI_ADMIN_EMAIL }).then((c) => {
- // if (c < 1) {
- // // Create root admin account (HEROKU ONLY)
- // return WIKI.db.User.create({
- // provider: 'local',
- // email: process.env.WIKI_ADMIN_EMAIL,
- // name: 'Administrator',
- // password: '$2a$04$MAHRw785Xe/Jd5kcKzr3D.VRZDeomFZu2lius4gGpZZ9cJw7B7Mna', // admin123 (default)
- // role: 'admin'
- // }).then(() => {
- // WIKI.logger.info('[AUTH] Root admin account created successfully!')
- // return true
- // }).catch((err) => {
- // WIKI.logger.error('[AUTH] An error occured while creating root admin account:')
- // WIKI.logger.error(err)
- // return err
- // })
- // } else { return true }
- // })
- // } else { return true }
- // })
- return this
- }
- }
|