-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpassportConfig.js
More file actions
54 lines (50 loc) · 1.51 KB
/
passportConfig.js
File metadata and controls
54 lines (50 loc) · 1.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
//This file handles the session data into browser cookies.
const LocalStrategy = require("passport-local").Strategy;
const { authenticate } = require('passport');
const { pool } = require("./dbConfig");
const bcrypt = require("bcrypt");
function initialize(passport){
const authenticateUser = (email, password, done)=> {
pool.query(
`SELECT * FROM users WHERE email = $1`, [email], (err, results)=>{
if(err){
throw err;
}
console.log(results.rows);
if(results.rows.length > 0){
const user = results.rows[0];
//to compare a password to a hashed password.
bcrypt.compare(password, user.password, (err, isMatch)=>{ //isMatch is a boolean value.
if(err){
throw err;
}
if(isMatch){
return done(null, user)
}else{
return done(null, false, {message:"Password is not correct!"});
}
});
}else{
return done(null, false, {message:"Email is not registered."});
}
}
);
}
passport.use(new LocalStrategy({
usernameField: "email",
passwordField: "password"
}, authenticateUser
));
passport.serializeUser((user, done)=> done(null, user.id));
passport.deserializeUser((id, done)=>{
pool.query(
`SELECT * FROM users WHERE id = $1`, [id], (err,results)=>{
if(err){
throw err;
}
return done(null, results.rows[0]);
}
);
});
}
module.exports = initialize;