-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathserver.js
56 lines (48 loc) · 1.58 KB
/
server.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
import express from 'express';
import bodyParser from 'body-parser';
import connectToDb from './db/connect';
import passport from 'passport';
import posts from './routes/posts.routes';
import user from './routes/user.routes';
import auth from './routes/auth.routes';
import User from './models/user';
const passportJWT = require("passport-jwt");
const JWTStrategy = passportJWT.Strategy;
const ExtractJWT = passportJWT.ExtractJwt;
const LocalStrategy = require('passport-local').Strategy;
const server = express();
connectToDb();
server.use(bodyParser.json());
server.use(bodyParser.urlencoded({
extended: false
}));
server.use(passport.initialize());
passport.use(new LocalStrategy({
usernameField: 'email',
passwordField: 'password'
},
User.authenticate()
));
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());
passport.use(new JWTStrategy({
jwtFromRequest: ExtractJWT.fromAuthHeaderAsBearerToken(),
secretOrKey : 'ILovePokemon'
},
function (jwtPayload, cb) {
//find the user in db if needed. This functionality may be omitted if you store everything you'll need in JWT payload.
return User.findById(jwtPayload.id)
.then(user => {
return cb(null, user);
})
.catch(err => {
return cb(err);
});
}
));
server.use('/api', posts);
server.use('/auth', auth);
server.use('/user', passport.authenticate('jwt', {session: false}), user);
server.listen(3005, () => {
console.log('server started - 3005');
});