-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
120 lines (106 loc) · 3.21 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
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
var express = require('express');
var browserify = require('browserify');
var React = require('react');
var path = require('path')
var app = express();
var db = require('./database');
var _ = require('lodash')
var bodyParser = require('body-parser');
var cookieParser = require('cookie-parser')
var session = require('express-session')
var passport = require('passport');
var Strategy = require('passport-local').Strategy;
var bcrypt = require('bcrypt');
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
app.set('port', (process.env.PORT || 4500));
app.use('/static', express.static(__dirname + '/public'));
app.use(cookieParser());
app.use(bodyParser.urlencoded({extended: true}));
app.use(session({secret: 'teststring', resave: false, saveUninitialized: false, cookie: {expires: new Date(Date.now() + 2592000000)}}));
app.use(passport.initialize());
app.use(passport.session());
var server = require('http').createServer(app);
server.listen((
process.env.PORT || app.get('port')), function() {
console.log("Express server listening on port %d ", server.address().port);
});
app.get('/database', function(req, res) {
var s = req.query.id;
var d = _.words(s, /[^, ]+/g)
db.getItemData(d, res)
});
app.get('/auth/user', function(req,res) {
if (req.user != undefined)
res.send(req.user.user);
})
app.post('/login', passport.authenticate('login', {
successRedirect: '/history',
failureRedirect: '/bookmark'
})
);
app.post('/register', passport.authenticate('register', {
successRedirect: '/history',
failureRedirect: '/bookmark'
})
//console.log(req.body);
);
app.get('*', function(req, res) {
res.sendFile(path.resolve(__dirname, 'public', 'index.html'))
});
//Passport Configs
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
db
.User
.findById(id, function(err, user) {
if (err) {
return done(err);
}
done(null, user);
});
});
passport.use('register', new Strategy({usernameField: 'user', passwordField: 'pass', passReqToCallback: true}, function(req, user, pass, done) {
db
.User
.findOne({'user': user}, function(err, u) {
if (err)
return done(err)
if (u) {
return done(null, false, "username taken")
} else {
var u = new db.User({_id: new mongoose.Types
.ObjectId(), user: user, pass: bcrypt.hashSync(pass, 5), apikey: 0, bookmarks: [], investments: [
{}
]})
u.save(function(err, newuser) {
if (err) {
return done(err);
}
return done(null, newuser);
})
}
})
}))
passport.use('login', new Strategy({usernameField: 'user', passwordField: 'pass', passReqToCallback: true}, function(req, user, pass, done) {
db
.User
.findOne({'user': user}, function(err, u) {
if (err){
console.log (err)
return done(err)
}
if (!u){
console.log("user wrong")
return done(null, false, "user not found")
}
if (!bcrypt.compareSync(pass, u.pass)){
console.log("pass wrong")
return done(null, false, "wrong password")
}
console.log("login success")
return done(null, u)
})
}))