|
@@ -4,87 +4,89 @@
|
|
|
|
|
|
const _ = require('lodash')
|
|
|
|
|
|
-module.exports = (passport) => {
|
|
|
+module.exports = {
|
|
|
+ init(passport) {
|
|
|
// Serialization user methods
|
|
|
|
|
|
- passport.serializeUser(function (user, done) {
|
|
|
- done(null, user._id)
|
|
|
- })
|
|
|
+ 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)
|
|
|
+ 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
|
|
|
+ // Load authentication strategies
|
|
|
|
|
|
- wiki.config.authStrategies = {
|
|
|
- list: _.pickBy(wiki.config.auth, strategy => strategy.enabled),
|
|
|
- socialEnabled: (_.chain(wiki.config.auth).omit('local').filter(['enabled', true]).value().length > 0)
|
|
|
- }
|
|
|
+ wiki.config.authStrategies = {
|
|
|
+ list: _.pickBy(wiki.config.auth, strategy => strategy.enabled),
|
|
|
+ socialEnabled: (_.chain(wiki.config.auth).omit('local').filter(['enabled', true]).value().length > 0)
|
|
|
+ }
|
|
|
|
|
|
- _.forOwn(wiki.config.authStrategies.list, (strategyConfig, strategyName) => {
|
|
|
- strategyConfig.callbackURL = `${wiki.config.site.host}/login/${strategyName}/callback`
|
|
|
- require(`../authentication/${strategyName}`)(passport, strategyConfig)
|
|
|
- wiki.logger.info(`Authentication Provider ${_.upperFirst(strategyName)}: OK`)
|
|
|
- })
|
|
|
+ _.forOwn(wiki.config.authStrategies.list, (strategyConfig, strategyName) => {
|
|
|
+ strategyConfig.callbackURL = `${wiki.config.site.host}/login/${strategyName}/callback`
|
|
|
+ require(`../authentication/${strategyName}`)(passport, strategyConfig)
|
|
|
+ wiki.logger.info(`Authentication Provider ${_.upperFirst(strategyName)}: OK`)
|
|
|
+ })
|
|
|
|
|
|
- // Create Guest account for first-time
|
|
|
+ // Create Guest account for first-time
|
|
|
|
|
|
- return wiki.db.User.findOne({
|
|
|
- where: {
|
|
|
- provider: 'local',
|
|
|
- email: 'guest@example.com'
|
|
|
- }
|
|
|
- }).then((c) => {
|
|
|
- if (c < 1) {
|
|
|
- return wiki.db.User.create({
|
|
|
+ return wiki.db.User.findOne({
|
|
|
+ where: {
|
|
|
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
|
|
|
- })
|
|
|
- }
|
|
|
- })
|
|
|
+ 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)
|
|
|
+ // .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 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 }
|
|
|
+ // })
|
|
|
+ }
|
|
|
}
|