| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 | 
							- const bcrypt = require('bcryptjs-then')
 
- /* global WIKI */
 
- // ------------------------------------
 
- // Local Account
 
- // ------------------------------------
 
- const LocalStrategy = require('passport-local').Strategy
 
- module.exports = {
 
-   init (passport, conf) {
 
-     passport.use('local',
 
-       new LocalStrategy({
 
-         usernameField: 'email',
 
-         passwordField: 'password'
 
-       }, async (uEmail, uPassword, done) => {
 
-         try {
 
-           const user = await WIKI.models.users.query().findOne({
 
-             email: uEmail.toLowerCase(),
 
-             providerKey: 'local'
 
-           })
 
-           if (user) {
 
-             await user.verifyPassword(uPassword)
 
-             if (!user.isActive) {
 
-               done(new WIKI.Error.AuthAccountBanned(), null)
 
-             } else if (!user.isVerified) {
 
-               done(new WIKI.Error.AuthAccountNotVerified(), null)
 
-             } else {
 
-               done(null, user)
 
-             }
 
-           } else {
 
-             // Fake verify password to mask timing differences
 
-             await bcrypt.compare((Math.random() + 1).toString(36), '$2a$12$irXbAcQSY59pcQQfNQpY8uyhfSw48nzDikAmr60drI501nR.PuBx2')
 
-             done(new WIKI.Error.AuthLoginFailed(), null)
 
-           }
 
-         } catch (err) {
 
-           done(err, null)
 
-         }
 
-       })
 
-     )
 
-   }
 
- }
 
 
  |