-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
95 lines (81 loc) · 2.85 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
var express = require('express')
, routes = require('./routes')
, user = require('./routes/user')
, url = require('./routes/url')
, home = require('./routes/home')
, website = require('./routes/website')
, comment = require('./routes/comment')
, login = require('./routes/login')
, http = require('http')
, path = require('path')
, fs = require('fs');
var Sequelize = require("sequelize");
var sequelize = new Sequelize('flashcar_zab', 'flashcar_zab', '~Password1', {host: 'flashcarddeck.com'});
var passport = require('passport')
, GoogleStrategy = require('passport-google').Strategy;
var User = sequelize.define('User', { openid: Sequelize.STRING, firstname: Sequelize.STRING, lastname: Sequelize.STRING }, {
instanceMethods: {
getFullname: function() {
return [this.firstname, this.lastname].join(' ')
}
}
});
passport.serializeUser(function(user, done) {
done(null, user);
});
passport.deserializeUser(function(user, done) {
done(null, user);
});
passport.use(new GoogleStrategy({
returnURL: 'http://zabonit.herokuapp.com/auth/google/return',
realm: 'http://zabonit.herokuapp.com/'
},
function(identifier, profile, done) {
User.findOrCreate({ openid: identifier, firstname: profile.name.givenName, lastname: profile.name.familyName }).done(done);
}
));
var app = express();
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.bodyParser());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieParser());
app.use(express.session({secret: '654yt325'}));
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(require('stylus').middleware(__dirname + '/public'));
app.use(express.static(path.join(__dirname, 'public')));
// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/', routes.index);
app.get('/users', user.list);
app.get('/url', url.find);
app.get('/home', home.index);
app.get('/login', login.index);
app.get('/test', user.test);
app.get('/website', website.index);
app.post('/comment', comment.add);
app.get('/comment', comment.index);
app.get('/test', ensureAuthenticated, function(req, res){
res.render('test', { user: req.user });
});
app.get('/auth/google', passport.authenticate('google'));
app.get('/auth/google/return', passport.authenticate('google', { successRedirect: '/home', failureRedirect: '/login' }));
app.get('/logout', function(req, res){
req.session.destroy();
res.redirect('/');
});
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});
function ensureAuthenticated(req, res, next) {
if (req.isAuthenticated()) { return next(); }
res.redirect('/home')
}