-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
75 lines (68 loc) · 2.09 KB
/
server.js
File metadata and controls
75 lines (68 loc) · 2.09 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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//Packages
const express = require("express"),
app = express(),
path = require("path"),
cors = require("cors"),
mongoose = require("mongoose"),
bodyParser = require("body-parser"),
cookieParser = require("cookie-parser"),
passport = require("passport"),
LocalStrategy = require("passport-local"),
JwtStrategy = require("passport-jwt").Strategy;
require("dotenv").config({path: path.resolve(__dirname, '.env')});
//Server Files
const User = require("./models/User"),
indexRoutes = require("./routes/index"),
taskRoutes = require("./routes/task"),
stepRoutes = require("./routes/step");
//DB Config
mongoose.connect(process.env.DATABASEURL || "mongodb://localhost/taskplanner", {useNewUrlParser: true, useUnifiedTopology: true});
mongoose.set("useFindAndModify", false);
mongoose.set('useCreateIndex', true);
//App Config
//Enables cookies in cross-origin request
app.use(cors({credentials: true, origin: true}));
app.use(cookieParser());
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
//Authentication Config
app.use(passport.initialize());
passport.use(new JwtStrategy({
//Extracts JWT from cookies
jwtFromRequest: (req) => {
let token = null;
if(req && req.cookies) {
token = req.cookies["access_token"];
};
return token;
},
secretOrKey: process.env.ACCESS_KEY
}, (payload, done) => {
//Finds and returns user on successful JWT authentication
User.findOne({_id: payload.sub}, (err, user) => {
if(err) {
return done(err, false);
};
if(!user) {
return done(null, false);
};
return done(null, user);
});
}));
//Uses passportLocalMongoose's authenticate method
passport.use(new LocalStrategy(User.authenticate()));
app.use((req, res, next) => {
//Creates req.user on each request
passport.authenticate("jwt", (err, user) => {
req.user = user;
next();
})(req, res);
});
//Run Routes
app.use("/", indexRoutes);
app.use("/tasks", taskRoutes);
app.use("/tasks/:taskId/steps", stepRoutes);
//Start Server
app.listen(process.env.PORT || 3001, () => {
console.log("Server Started");
});