-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
60 lines (49 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
56
57
58
59
60
var express = require('express');
var app = express();
app.use(express.static(__dirname + '/public'));
var mongoose = require('mongoose');
var db = mongoose.connect('mongodb://localhost/test');
var UserSchema = new mongoose.Schema({
username: String,
password: String,
email: String,
firstName: String,
lastName: String,
roles: [String]
});
var UserModel = mongoose.model("UserModel",UserSchema);
// var admin = new UserModel({username:"alice", password:"alice", firstName:"Alice",lastName:"Wonderland",
// roles: ["admin"]});
// admin.save();
// var student = new UserModel({username:"bob", password:"bob",
// firstName:"Bob",lastName:"Marley",
// roles: ["student"]});
// student.save();
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
app.use(passport.initialize());
var bodyParser = require('body-parser');
app.use(bodyParser.json()); // for parsing application/json
app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
passport.use(new LocalStrategy(
function(username,password, done)
{
UserModel.findOne({username: username, password: password}, function(err,user){
if(user){
return done(null, user);
}
return done(null, false, {message: 'Unable to Login'});
});
}));
passport.serializeUser(function(user,done){
done(null,user);
});
passport.deserializeUser(function(user,done){
done(null,user);
});
app.post("/login", passport.authenticate('local'), function(req,res){
console.log("/login");
console.log(req.user);
res.json(req.user);
});
app.listen(3000);