-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathpassportConfig.js
93 lines (84 loc) · 2.92 KB
/
passportConfig.js
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
const LocalStrategy = require('passport-local').Strategy;
const bcrypt = require('bcrypt');
const { Client } = require('pg');
const pg = new Client({
connectionString: process.env.DATABASE_URL || "postgres://postgres:postgres@localhost:5432/ethical_eating",
// ssl: {
// rejectUnauthorized: false
// }
});
pg.connect()
function initialize(passport) {
const authenticateLogin = (username, password, done) => {
getUserByUsernameInput(username).then((user) => {
if (user) { // if an account is found
compareUserPassword(password, user).then((match) => {
if (match) {
return done(null, user);
} else {
// password does not match user name
return done(null, false, {message: "Password is incorrect"});
}
});
} else { // the username does not exist
return done(null, false, {message: "Invalid Username"});
}
});
}
passport.use(new LocalStrategy({ usernameField: "username", passwordField: "password"},
authenticateLogin
));
passport.serializeUser((user, done) => done(null, user.id)); //store user.id in session
passport.deserializeUser((id, done) => { // uses id to obtain user details
getUserByID(id).then((userID) => {
if (userID){
return done(null, userID);
}
});
});
function getUserByUsernameInput(username){
return new Promise (function(resolve, reject) {
let query = `SELECT * FROM account WHERE username = '${username}'`;
pg.query(query, value = (err, result) => {
if(err){
throw err;
}
if (result.rows.length === 1) { // if an account is found
const user = result.rows[0];
resolve(user)
}
else {
resolve(false)
}
});
});
}
function compareUserPassword(passwordInput, user){
return new Promise (function(resolve, reject) {
bcrypt.compare(passwordInput, user.password, (err, match) => {
if (err) {
throw err;
}
if (match) {
resolve(true);
} else {
// password does not match user name
resolve(false);
}
});
});
}
function getUserByID(id){
return new Promise (function(resolve, reject) {
let query = `SELECT * FROM account WHERE id = ${id}`;
pg.query(query, (err,result) => {
if (err) {
throw err;
} else {
resolve(result.rows[0]);
}
});
});
}
}
module.exports = initialize;