-
Notifications
You must be signed in to change notification settings - Fork 1
/
app.js
115 lines (94 loc) · 3.23 KB
/
app.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
var express = require('express')
, http = require('http')
, path = require('path')
, database = require("./config/database")
, pivotal = require("./controllers/pivotal")
, inspect = require('eyes').inspector({ stream: null })
, flash = require('connect-flash');
var passport = require('passport')
, LocalStrategy = require('passport-local').Strategy;
var app = express();
database.init(function(db){
var findById = function(id, fn) {
db.users.findOne({id: id}, function(err, user){
if(user){
fn(null, user);
}else{
fn(new Error('User ' + id + ' does not exist'));
}
});
};
var findByUsername = function(username, fn) {
db.users.findOne({email: username}, function(err, user){
return fn(null, user);
});
};
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
findById(id, function (err, user) {
done(err, user);
});
});
passport.use(new LocalStrategy(
function(username, password, done) {
process.nextTick(function () {
findByUsername(username, function(err, user) {
if (err) { return done(err); }
if (!user) {
pivotal.access({username: username, password: password}, function(result){
if(typeof result === 'object'){
var guid = result.token.guid[0];
var id = result.token.id[0]._;
db.users.save({id: id, email: username, password: password, token: guid}, { safe: true }, function(err, user){
if(user){
return done(null, user);
}
});
}else{
return done(null, false, { message: 'Access denied.'});
}
});
}else{
if (user.password !== password) { return done(null, false, { message: 'Invalid password' }); }
return done(null, user);
}
});
});
}
));
app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.session({ secret: 'keyboard cat' }));
app.use(flash());
app.use(passport.initialize());
app.use(passport.session());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
});
app.configure('development', function(){
app.use(express.errorHandler());
});
var server = http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});
var io = require('socket.io').listen(server);
require("./controllers/home")(app);
require("./controllers/games")(app, db);
require("./controllers/socketio")(io);
require("./controllers/pivotalMethods")(app, db);
app.post('/login',
passport.authenticate('local', { failureRedirect: '/login', failureFlash: true }),
function(req, res) {
res.redirect('/');
});
});