-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathapp.js
More file actions
103 lines (85 loc) · 2.86 KB
/
app.js
File metadata and controls
103 lines (85 loc) · 2.86 KB
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
/**
* Module dependencies.
*/
var express = require('express')
, http = require('http')
, path = require('path')
, flash = require('connect-flash')
, passport = require('passport')
, localStrategy = require('passport-local').Strategy
, sessionHandler = require('./lib/session')
, mongoose = require('mongoose')
, lessMiddleware = require('less-middleware');
var app = express();
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.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieParser('your secret here'));
app.use(express.session());
app.use(flash());
app.use(passport.initialize());
app.use(passport.session());
app.use(app.router);
app.use(lessMiddleware(path.join(__dirname, '/public')));
app.use(express.static(path.join(__dirname, 'public')));
});
app.configure('development', function() {
app.use(express.errorHandler());
});
if (app.settings.env == 'development') {
app.set('hosted image url', __dirname+'/public/images');
app.set('db url', 'mongodb://localhost/devfolio');
}
mongoose.connect(app.get('db url'));
/*
* Set up Passport
*/
passport.serializeUser(sessionHandler.serialize);
passport.deserializeUser(sessionHandler.deserialize);
passport.use(sessionHandler.localStrategy);
/*
* Load Routes
*/
var routes = require('./routes')({ app: app });
/*
* Static Routes
*/
//app.get('/', sessionHandler.verifyNotLoggedIn, routes.index);
app.get('/', sessionHandler.verifyNotLoggedIn, routes.betaForm);
app.post('/', sessionHandler.verifyNotLoggedIn, routes.betaSignup);
/*
* User creation routes
*/
app.get('/new_user', sessionHandler.verifyNotLoggedIn, routes.newUser);
app.post('/new_user', sessionHandler.verifyNotLoggedIn, routes.newUser);
app.post('/register', sessionHandler.verifyNotLoggedIn, routes.createUser);
/*
* Validation Routes
*/
app.post('/validate_email', routes.validateEmail);
app.post('/validate_username', routes.validateUsername);
/*
* Session Management
*/
app.get('/login', sessionHandler.verifyNotLoggedIn, routes.getLoginForm);
app.post('/login', sessionHandler.verifyNotLoggedIn, sessionHandler.authenticate, routes.login);
app.get('/logout', routes.logout);
/*
* User Dashboard and Editing Routes
*/
app.get('/dash', sessionHandler.verifyLoggedIn, routes.dash);
/*
* Folio Routes
*/
app.post('/tmp/avatar', sessionHandler.verifyLoggedIn, routes.addAvatar);
app.post('/upload', sessionHandler.verifyLoggedIn, routes.uploadAvatar);
app.get('/:username', routes.folio);
app.post('/:username', sessionHandler.verifyLoggedIn, routes.editUser);
http.createServer(app).listen(app.get('port'), function() {
console.log("Express server listening on port " + app.get('port'));
});