auth.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. 'use strict'
  2. /* global wiki */
  3. const _ = require('lodash')
  4. module.exports = {
  5. init(passport) {
  6. // Serialization user methods
  7. passport.serializeUser(function (user, done) {
  8. done(null, user._id)
  9. })
  10. passport.deserializeUser(function (id, done) {
  11. wiki.db.User.findById(id).then((user) => {
  12. if (user) {
  13. done(null, user)
  14. } else {
  15. done(new Error(wiki.lang.t('auth:errors:usernotfound')), null)
  16. }
  17. return true
  18. }).catch((err) => {
  19. done(err, null)
  20. })
  21. })
  22. // Load authentication strategies
  23. wiki.config.authStrategies = {
  24. list: _.pickBy(wiki.config.auth, strategy => strategy.enabled),
  25. socialEnabled: (_.chain(wiki.config.auth).omit('local').filter(['enabled', true]).value().length > 0)
  26. }
  27. _.forOwn(wiki.config.authStrategies.list, (strategyConfig, strategyName) => {
  28. strategyConfig.callbackURL = `${wiki.config.site.host}/login/${strategyName}/callback`
  29. require(`../authentication/${strategyName}`)(passport, strategyConfig)
  30. wiki.logger.info(`Authentication Provider ${_.upperFirst(strategyName)}: OK`)
  31. })
  32. // Create Guest account for first-time
  33. return wiki.db.User.findOne({
  34. where: {
  35. provider: 'local',
  36. email: 'guest@example.com'
  37. }
  38. }).then((c) => {
  39. if (c < 1) {
  40. return wiki.db.User.create({
  41. provider: 'local',
  42. email: 'guest@example.com',
  43. name: 'Guest',
  44. password: '',
  45. role: 'guest'
  46. }).then(() => {
  47. wiki.logger.info('[AUTH] Guest account created successfully!')
  48. return true
  49. }).catch((err) => {
  50. wiki.logger.error('[AUTH] An error occured while creating guest account:')
  51. wiki.logger.error(err)
  52. return err
  53. })
  54. }
  55. })
  56. // .then(() => {
  57. // if (process.env.WIKI_JS_HEROKU) {
  58. // return wiki.db.User.findOne({ provider: 'local', email: process.env.WIKI_ADMIN_EMAIL }).then((c) => {
  59. // if (c < 1) {
  60. // // Create root admin account (HEROKU ONLY)
  61. // return wiki.db.User.create({
  62. // provider: 'local',
  63. // email: process.env.WIKI_ADMIN_EMAIL,
  64. // name: 'Administrator',
  65. // password: '$2a$04$MAHRw785Xe/Jd5kcKzr3D.VRZDeomFZu2lius4gGpZZ9cJw7B7Mna', // admin123 (default)
  66. // role: 'admin'
  67. // }).then(() => {
  68. // wiki.logger.info('[AUTH] Root admin account created successfully!')
  69. // return true
  70. // }).catch((err) => {
  71. // wiki.logger.error('[AUTH] An error occured while creating root admin account:')
  72. // wiki.logger.error(err)
  73. // return err
  74. // })
  75. // } else { return true }
  76. // })
  77. // } else { return true }
  78. // })
  79. }
  80. }