-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpolyhedron.js
105 lines (90 loc) · 2.47 KB
/
polyhedron.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
var application_root = __dirname,
userdb = require("./modules/userdb"),
express = require("express"),
path = require("path"),
passport = require("passport"),
LocalStrategy = require('passport-local').Strategy;
// Global constants.
var config = {
// Maximum age of session in ms.
MAX_SESSION_AGE: 300000,
COOKIE_SECRET: "503a3d9f7244655510000001",
HTTP_PORT: 4242
};
// User database initialization.
var UserDb = new userdb.UserDB(config);
if(!UserDb.connect()) return;
// Express config.
var app = express();
app.configure(function () {
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieParser(config.COOKIE_SECRET));
app.use(express.session({secret: config.COOKIE_SECRET}));
app.use(passport.initialize());
app.use(passport.session());
app.use(express.static(path.join(application_root, "public")));
app.use(app.router);
app.use(function(err, req, res, next) { render_error(err, res); })
app.set('view engine', 'jade');
});
// Passport config.
passport.use(new LocalStrategy(
function(username, password, done) {
UserDb.lookupUser(username, password, done);
})
);
passport.serializeUser(function(user, done) {
UserDb.createSession(user, done);
});
passport.deserializeUser(function(sid, done) {
UserDb.lookupSession(sid, done);
});
// Error handling.
var error_msgs = {
403: "You shall not go there.",
404: "Wtf?",
500: "I am not feeling well."
}
function render_error(err, res, num) {
var status = num ? num : 500;
var message = err ? err : error_msgs[status];
res.status(status).render('error', { error: status, msg: message })
}
// Express API.
app.post('/api/login',
function (req, res, next) {
passport.authenticate('local',
function (err, user, info) {
if (err)
return next(err);
if (!user)
return render_error(null, res, 403);
res.render('home', {"user": user});
}
)(req, res, next);
});
app.post('/api/register',
function (req, res, next) {
UserDb.addUser(req.body.username, req.body.email, req.body.password, function(success) {
if(!success) {
render_error(null, res, 500);
} else {
res.redirect('/index.html');
}
});
});
app.get('/home',
function (req, res, next) {
// req.user is set if session is established!
if(!req.user)
render_error(null, res, 403);
else
res.render('home', {"user": user});
});
app.get('*',
function (req, res, next) {
render_error(null, res, 404);
});
// Launch server
app.listen(config.HTTP_PORT);