-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
80 lines (67 loc) · 2.19 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
var express = require('express')
, app = express()
, http = require('http')
, server = http.createServer(app)
, engine = require('ejs-locals')
, mongoose = require('mongoose')
, passport = require('passport')
, config = require('./config')
, authConfig = require('./authConfig')
, boughtIt = require('./model/boughtIt');
authConfig.init();
app.configure(function () {
app.engine('ejs', engine);
app.set('view engine', 'ejs');
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.session({ secret: 'friendo mkfriend' }));
app.use(express.csrf());
app.use(passport.initialize());
app.use(passport.session());
app.use(function (req, res, next) {
res.locals.user = req.user;
res.locals.isAuthenticated = req.isAuthenticated();
res.locals.token = req.session._csrf;
next();
});
app.use(app.router);
app.use('/public', express.static(__dirname + '/public'));
});
app.get('/', ensureAuthenticated, function (req, res) {
res.render('index', { title: 'Home' });
});
app.get('/boughtit', function (req, res) {
res.render('boughtit', { title: 'Bought It' });
});
app.post('/boughtit', function (req, res) {
boughtIt.create({
userId: req.user._id,
vendor: req.body['select-vendor'],
price: req.body.price
}, function () {
res.render('boughtit', { title: 'Bought it Saved' });
});
});
app.get('/madeit', function (req, res) {
res.render('madeit', { title: 'Made It' });
});
app.get('/auth/facebook', passport.authenticate('facebook'), function (req, res) { });
app.get('/auth/facebook/callback',
passport.authenticate('facebook', { failureRedirect: '/' }),
function(req, res) {
res.redirect('/');
});
mongoose.connect(config.mongo.connectionString);
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function () {
console.log('Listening on port 3000.');
app.listen(3000);
});
function ensureAuthenticated(req, res, next) {
if (req.isAuthenticated()) {
return next();
}
res.render('index', { title: 'Home' });
}