-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
169 lines (144 loc) · 4.45 KB
/
app.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
require("dotenv").config();
const bodyParser = require("body-parser");
const cookieParser = require("cookie-parser");
const express = require("express");
const favicon = require("serve-favicon");
const hbs = require("hbs");
const mongoose = require("mongoose");
const logger = require("morgan");
const path = require("path");
const passport = require("passport");
const session = require("express-session");
const LocalStrategy = require("passport-local").Strategy;
const MongoStore = require("connect-mongo")(session);
const User = require("./models/userModel");
const bcrypt = require("bcrypt");
const flash = require("connect-flash");
mongoose
.connect(process.env.MONGODB_URI, { useNewUrlParser: true })
.then((x) => {
console.log(
`Connected to Mongo! Database name: "${x.connections[0].name}"`
);
})
.catch((err) => {
console.error("Error connecting to mongo", err);
});
mongoose.set('useFindAndModify', false);
const app_name = require("./package.json").name;
const debug = require("debug")(
`${app_name}:${path.basename(__filename).split(".")[0]}`
);
const app = express();
// Middleware Setup
app.use(logger("dev"));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(flash());
// Express View engine setup
app.use(
require("node-sass-middleware")({
src: path.join(__dirname, "public"),
dest: path.join(__dirname, "public"),
sourceMap: true,
})
);
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "hbs");
app.use(express.static(path.join(__dirname, "public")));
app.use(favicon(path.join(__dirname, "public", "images", "favicon.ico")));
// express-session configuration --> use mongostore in the setup then sessions get stored
app.use(
session({
secret: process.env.SECRET,
cookie: { maxAge: 24 * 60 * 60 * 1000 }, // 1 day
store: new MongoStore({
mongooseConnection: mongoose.connection,
resave: true,
saveUninitialized: true,
ttl: 24 * 60 * 60, // 1 day
}),
})
);
// associate user with a session // store the user into the session
passport.serializeUser((user, callback) => {
callback(null, user._id);
});
passport.deserializeUser((id, callback) => {
User.findById(id)
.then((user) => {
callback(null, user);
})
.catch((error) => {
callback(error);
});
});
// local strategy ===> how to move the strategies to a different folder an require it here??? ask Hendrik / Mir
passport.use(
new LocalStrategy(
{
usernameField: 'email',
passwordField: 'passwd',
},
(email, password, callback) => {
User.findOne({email})
.then((user) => {
if (!user) {
return callback(null, false, { message: "No such user" });
}
if (!bcrypt.compareSync(password, user.password)) {
return callback(null, false, { message: "Wrong password" });
}
callback(null, user);
})
.catch((error) => {
callback(error);
});
}
)
);
// google strategy
const GoogleStrategy = require("passport-google-oauth20").Strategy;
passport.use(
new GoogleStrategy(
{
clientID: process.env.GOOGLE_CLIENT_ID,
clientSecret: process.env.GOOGLE_CLIENT_SECRET,
callbackURL: "/auth/google/callback",
},
(accessToken, refreshToken, profile, done) => {
// to see the structure of the data in received response:
console.log("Google account details:", profile);
// User.findOne({ googleID: profile.id })
User.findOne({ email: profile.emails[0].value })
.then((user) => {
if (user) {
done(null, user);
return;
}
User.create({
googleID: profile.id,
name: profile.displayName,
email: profile.emails[0].value,
// verifiedEmail: profile.emails[0].verified, // UNCOMMENT THIS LINE TO RESTORE AUTH EMAIL VERIFICATION
})
.then((newUser) => {
done(null, newUser);
})
.catch((err) => done(err)); // closes User.create()
})
.catch((err) => done(err)); // closes User.findOne()
}
)
);
//Passport setup
app.use(passport.initialize());
app.use(passport.session());
const index = require("./routes/index");
app.use("/", index);
const auth = require("./routes/auth");
app.use("/auth", auth);
const garden = require("./routes/garden");
app.use("/garden", garden);
module.exports = app;